django中 对Mysql数据库的建表教程
Django操作Mysql数据库:
1.1 在settings中,配置数据库相关参数,所以无需修改,这里我们看一下:
DATABASES = {
'default': {
\# 这里可以指定使用的数据库类型,例如mysql
'ENGINE': 'django.db.backends.mysql',
'NAME': 'djangomysql',
'USER':'root',
'PASSWORD':'******',
'HOST':'localhost',
'PORT':'3306',
'OPTIONS': {'isolation\_level': None}
}
}
1.2 编译models.py Django通过自定义python类的形式来定义具体的模型,每个模型的物理存
在方式就是一个python的Class,每个模型代表数据库中的一张表,每个类的实例代表数据库中的
一行数据,类中的每个变量代表数据库中的一列字段。
Django通过模型,将python代码和数据库操作结合起来,实现对SQL查询语言的封装。也就
是说,你可以不会管理数据库,可以不会SQL语言,你同样能通过python的代码进行数据库的操
作。DJango通过ORM对数据库进行操作,下面直接看代码:
from django.db import models
\# Create your models here.
class UserInfo(models.Model):
'''
创建两个字段,最大长度是32,类型是char
'''
user = models.CharField(max\_length= 32)
pwd = models.CharField(max\_length= 32)
这里我们创建了两个字段,分别保存用户的名称和密码。
上面的代码,相当于下面的原生SQL语句。
CREATE TABLE UserInfo (
"id" serial NOT NULL PRIMARY KEY,
"user" varchar(30) NOT NULL,
"pwd" varchar(30) NOT NULL
);
注意:
Django默认自动创建自增主键ID,当然也可以自己指定主键。 上面的SQL语法基于PostgreSQL
更多字段和参数
每个字段有一些特有的参数,例如,CharField 需要 max\_length 参数来指定VARCHAR 数据
库字段的大小。还有一些适用于所有字段的通用参数。这些参数在文档中有详细定义,这里我们学
习一下最常用的:
<1> CharField
字符串字段, 用于较短的字符串.
CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层
限制该字段所允许的最大字符数.
<2> IntegerField
\#用于保存一个整数.
<3> FloatField
一个浮点数. 必须 提供两个参数:
参数 描述
max\_digits 总位数(不包括小数点和符号)
decimal\_places 小数位数
举例来说, 要保存最大值为 999 (小数点后保存2位),你要这样定义字段:
models.FloatField(..., max\_digits=5, decimal\_places=2)
要保存最大值一百万(小数点后保存10位)的话,你要这样定义:
models.FloatField(..., max\_digits=19, decimal\_places=10)
admin 用一个文本框()表示该字段保存的数据.
<4> AutoField
一个 IntegerField, 添加记录时它会自动增长. 你通常不需要直接使用这个字段;
自定义一个主键:my\_id=models.AutoField(primary\_key=True)
如果你不指定主键的话,系统会自动添加一个主键字段到你的 model.
<5> BooleanField
A true/false field. admin 用 checkbox 来表示此类字段.
<6> TextField
一个容量很大的文本字段.
admin 用一个
更多参数
(1)null
如果为True,Django 将用NULL 来在数据库中存储空值。 默认值是 False.
(1)blank
如果为True,该字段允许不填。默认为False。
要注意,这与 null 不同。null纯粹是数据库范畴的,而 blank 是数据验证范畴的。
如果一个字段的blank=True,表单的验证将允许该字段是空值。如果字段的blank=False,该字段就是必填
的。
(2)default
字段的默认值。可以是一个值或者可调用对象。如果可调用 ,每有新对象被创建它都会被调用。
(3)primary\_key
如果为True,那么这个字段就是模型的主键。如果你没有指定任何一个字段的primary\_key=True,
Django 就会自动添加一个IntegerField字段做为主键,所以除非你想覆盖默认的主键行为,
否则没必要设置任何一个字段的primary\_key=True。
(4)unique
如果该值设置为 True, 这个数据字段的值在整张表中必须是唯一的
(5)choices
由二元组组成的一个可迭代对象(例如,列表或元组),用来给字段提供选择项。
如果设置了choices ,默认的表单将是一个选择框而不是标准的文本框,而且这
个选择框的选项就是choices 中的选项。
1.3 在终端创建表 我们需要在pycharm的teminal中通过命令创建数据库的表,有两条命令,分别是:
生成同步数据库的脚本代码
python manage.py makemigrations
通过运行makemigrations 命令,相当于告诉Django,你对模型有改动,并且你想把这些改动保存
为一个“迁移”(migration)。
migrations是Django保存模型修改记录的文件,这些文件保存在磁盘上,我们可以打开这个文件看一下,里面保存的都是可读并且
可编译的内容,方便我们随时手动修改。
然后同步数据库:
python manage.py migrate