基本命令

1、新建一个django项目

django-admin.py startproject project-name

2、新建一个app

python manage.py startapp app-name

3、同步数据库

python manage.py syncdb

注意:Django 1.7.1及以上的版本需要用以下命令
python manage.py makemigrations
python manage.py migrate

这种方法可以创建表,当你在models.py中新增了类时,运行它就可以自动在数据库中创建表了,不用手动创建。
备注:对已有的 models 进行修改,Django 1.7之前的版本的Django都是无法自动更改表结构的,不过有第三方工具south

4、运行开发服务器

python manage.py runserver 0.0.0.0:8000

5、清空数据库

python manage.py flush

此命令会询问是 yes 还是 no, 选择 yes 会把数据全部清空掉,只留下空表。

6、创建超级管理员

python manage.py createsuperuser

7、导出数据、导入数据

python manage.py dumpdata appname > appname.json
python manage.py loaddata appname.json

8、django项目环境终端

python manage.py shell

如果你安装了bpython或者ipython,会自动调用他们的界面

9、数据库执行命令

python manage.py dbshell

django会进行到settings中设置的数据库,如果是mysql或者postgresql,会要求输入用户名和密码

在这个终端可以输入sql语句

10、更多命令

在终端上输入python manage.py 回车,就可以看到详细的列表

问题收集:

生成同步数据库的脚本:python manage.py makemigrations

  同步数据库:  python manage.py migrate

注意:在开发过程中,数据库同步误操作之后,难免会遇到后面不能同步成功的情况,解决这个问题的一个简单粗暴方法是把migrations目录下

的脚本(除__init__.py之外)全部删掉,再把数据库删掉之后创建一个新的数据库,数据库同步操作再重新做一遍。

提示: 如若要从models里修改表,可以再次运行

python manage.py makemigrations

python manage.py maigrate

如果class里 字段没有默认值会报错,解决方式如下:

age = models.IntegerField()  # 这里没写默认值
报错:You are trying to add a non-nullable field 'age' to userinfor without a default; we can't do that (the database needs something to populate existing rows).
Please select a fix:
) Provide a one-off default now (will be set on all existing rows with a null value for this column)
) Quit, and let me add a default in models.py
Select an option:
选择2退出,或者age = models.IntegerField(null=True) ; age = models.IntegerField(default=) 设置空,或者默认值
然后继续,python manage.py makemigrations
python manage.py migrate

对Django数据库操作的记录都在这:

使用Model对数据库进行增删改查:

1、views.py 访问index路径时,执行这个添加的函数

def index(req):

    from app_01 import  models
   #增
# models.UserGroup.objects.create(title='销售部')
# models.UserInfor.objects.create(user='root',password='pwd',age=18,ug_id=1) #查
# group_list = models.UserGroup.objects.all()
  #group_list = models.UserGroup.objects.filter(id=1)
  # print(group_list)
  # 这里代码是从上至下执行,filter 是筛选器,配合了不起的 双下划线 __
  #group_list = models.UserGroup.objects.filter(id__gt=1).first() #只取第一个
  #group_list = models.UserGroup.objects.filter(id__lt=1)
  #删除
  # group_list = models.UserGroup.objects.filter(id=1).delete()
  #改
  group_list = models.UserGroup.objects.filter(id=1).update(title='打鸟不')
  group_list = models.UserGroup.objects.all()
    #group_list QuerySet类型(列表)
#QuerySet类型[obj,obj,obj]
 # print(group_list)
#for i in group_list:
# print(i.id,i.title)
#return HttpResponse("....ok") #这里将数据显示到了后台
  return render(req,'newindex.html',{'group_list':group_list}) #这里将数据显示到前端

2、urls.py 和  index.html

urlpatterns = [
url(r'index/',views.index)
} #路由系统
------------------------------------------------------------
{% for row in group_list %}
<li>
{{ row.id }}----{{ row.title }}
</li>
{% endfor %} #前端遍历代码

3、models.py 外键约束

# Create your models here.
from django.db import models
class UserGroup(models.Model): title = models.CharField(max_length=) #一个部门可以对应多个用户
# 一 对 多, 多的表 添加外键 class UserInfor(models.Model):
nid = models.BigAutoField(primary_key=True)
user = models.CharField(max_length=)
password = models.CharField(max_length=)
age = models.IntegerField(default=)
ug = models.ForeignKey("UserGroup",null=True)
#默认生成一个 ug_id 外键列

4、查看数据库多了‘销售部’了吗

成功添加

类代指表,对象代指数据

												

Django之常用命令以及问题汇总的更多相关文章

  1. web 架构 /http协议,状态码,django中常用命令

    什么是web应用? web应用 架构 :B/S架构 | C/S架构 网站:BS架构其实就是应用程序: B是浏览器 S是sever(实现了wsgi协议,实现了socket的服务端) + applicat ...

  2. Django中常用命令

    Django 基本命令 熟练使用Django常用命令能让你事半功倍!!!! 1. 新建一个 django project django-admin.py startproject project-na ...

  3. Linux常用命令速查-汇总篇

    Linux常用命令速查-用户管理 Linux常用命令速查-文件管理 Linux常用命令速查-系统监控 Linux常用命令速查-网络管理 Linux常用命令速查-定时任务 Linux常用命令速查-Vim

  4. Django - Python3 常用命令

    1.创建Django 项目 执行命令 django-admin.py startproject project_name 2.创建app 执行命令 注意:要先进入项目目录下,cd project_na ...

  5. django 之 常用命令

    Django 基本命令 本节主要是为了让您了解一些django最基本的命令,请尝试着记住它们,并且多多练习下 1. 新建一个 django project django-admin.py startp ...

  6. repo常用命令及常见问题汇总

    1.执行repo命令的时候,总是显示“project xx no found” 解决: (1)先执行“repo forall -c pwd” 显示所有project的路径,按照这个来写project参 ...

  7. 20145222《信息安全系统设计基础》Linux常用命令汇总

    学习Linux时常用命令汇总 通过Ctrl+f键可在该网页搜索到你想要的命令. Linux中命令格式为:command [options] [arguments] //中括号代表是可选的,即有些命令不 ...

  8. GIT 版本控制常用命令学习汇总

    GIT 版本控制常用命令汇总 git version 查看当前git版本信息 git help 获取全部命令帮助信息 git help <command> 获取指定命令帮助信息 git c ...

  9. Oozie命令行常用命令汇总[转]

    Oozie命令行常用命令汇总 有时候脚本跑多了就不愿意在OozieWeb端去看脚本的运行情况了.还好Oozie提供了很多命令行命令.能通过命令行直接检索自己想看到的脚本信息.在这里简单进行一下总结.一 ...

随机推荐

  1. IntelliJ IDEA神器使用技巧笔记

    1. Alt + 数字 打开idea 快捷键打开相应的窗口: 高效定位代码: 无处不在的跳转 1.项目间的跳转: Windows ->   ctrl+alt+[   /  ] 2.文件之间的跳转 ...

  2. selenium自动化测试通过localstorage绕过登陆

    引言: 做自动化测试,尤其是通过page object模式做UI自动化测试,登陆是个很麻烦的事情,比如你想对某个页面进行测试,一般直接链接到那个页面是不可能的,总是需要先登陆,然后刷新页面才能到想要的 ...

  3. c++官方文档-枚举-联合体-结构体-typedef-using

    #include<iostream> #include <new> #include<stdio.h> using namespace std; /** * url ...

  4. 0_Simple__simpleOccupancy

    计算核函数调用使得占用率,并尝试使用 runtime 函数自动优化线程块尺寸,以便提高占用率. ▶ 源代码. #include <iostream> #include "cuda ...

  5. ASP.Net在web.config中设置上传文件的大小方法

    修改Webcong文件:<system.web><httpRuntime maxRequestLength="40960"   //即40MB,1KB=1024u ...

  6. 创建一个多进程(multiprocessing.Process)

    进程是资源的集合,每个进程至少包含一个线程 import multiprocessing #导入进程模块import time, threading #导入线程 def thread_run(): p ...

  7. ESCP打印机数据解密

    通过串口调试工具 抓取到的16进制文本; 如下 然后打开我们的文档,查看命令数据内容. 详情请密我QQ:1161588342  说明加好友原因

  8. fb bin_debug下的swf不见了

    fb清理了所选的项目,如果代码有错误,会自动删除bin_debug目录下的swf.这种情况,构建项目是无法自动生成swf的,只有将代码报错的地方修改正错了.选构建项目才会在bin_debug目录下生成 ...

  9. python 3 属性查找与绑定方法

    1.属性查找 类有两种属性:数据属性和函数属性 (1)类的数据属性是所有对象共享的 #类的数据属性是所有对象共享的,id都一样 class OldboyStudent: school='oldboy' ...

  10. Technology, globalisation and the squeeze on good jobs

    Technology, globalisation and the squeeze on good jobs技术与全球化冲击好工作“Highest stock market EVER! Jobs ar ...