Django中内嵌了ORM框架,不需要直接编写SQL语句进行数据库操作,而是通过定义模型
O-object,类对象
R-relation,数据表
M-mapping,映射。类,操作模型类来完成对数据库中表的增删改查和创建等操作。
映射关系:
类:sql语句table表
类成员变量:table表中的字段、类型和约束
类对象:sql表的表记录
操作数据库的步骤
- 在setting里面配置数据库信息
- 在models.py里面定义模型类
- 生成数据库迁移文件并执行迁移文件
- 通过模型类对象提供的方法或属性完成数据表的增删改查操作
配置数据库信息(以mysql为例子)
- 安装pymysql
pip install PyMySQL - 在Django的工程同名子目录的
__init__
.py文件中添加如下语句-
from pymysql import install_as_MySQLdb
install_as_MySQLdb()
- 配置数据库
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'HOST': '127.0.0.1', # 数据库主机
'PORT': 3306, # 数据库端口
'USER': 'root', # 数据库用户名
'PASSWORD': 'root', # 数据库用户密码
'NAME': 'databasename' # 数据库名字
}
}
定义模型类
在models.py下书写模型类,继承于模型类
from django.db import models
# Create your models here.
class myModel(models.Model):
# 属性名 = models.字段类型(约束选项, verbose_name="注释")
name = models.CharField(max_length=16)
age = models.SmallIntegerField(null= True)
字段类型
类型 | 说明 |
---|---|
AutoField | 自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性 |
BooleanField | 布尔字段,值为True或False |
NullBooleanField | 支持Null、True、False三种值 |
CharField | 字符串,参数max_length表示最大字符个数,对应mysql中的varchar |
TextField | 大文本字段,一般大段文本(超过4000个字符)才使用。 |
IntegerField | 整数 |
DecimalField | 十进制浮点数, 参数max_digits表示总位数, 参数decimal_places表示小数位数,常用于表示分数和价格 Decimal(max_digits=7, decimal_places=2) ==> 99999.99~ 0.00 |
FloatField | 浮点数 |
DateField | 日期 参数auto_now表示每次保存对象时,自动设置该字段为当前时间。 参数auto_now_add表示当对象第一次被创建时自动设置当前。 参数auto_now_add和auto_now是相互排斥的,一起使用会发生错误。 |
TimeField | 时间,参数同DateField |
DateTimeField | 日期时间,参数同DateField |
FileField | 上传文件字段,django在文件字段中内置了文件上传保存类, django可以通过模型的字段存储自动保存上传文件, 但是, 在数据库中本质上保存的仅仅是文件在项目中的存储路径!! |
ImageField | 继承于FileField,对上传的内容进行校验,确保是有效的图片 |
约束选项
选项 | 说明 |
---|---|
null | 如果为True,表示允许为空,默认值是False。相当于python的None |
blank | 如果为True,则该字段允许为空白,默认值是False。 相当于python的空字符串,“” |
db_column | 字段的名称,如果未指定,则使用属性的名称。 |
db_index | 若值为True, 则在表中会为此字段创建索引,默认值是False。 相当于SQL语句中的key |
default | 默认值,当不填写数据时,使用该选项的值作为数据的默认值。 |
primary_key | 如果为True,则该字段会成为模型的主键,默认值是False,一般不用设置,系统默认设置。 |
unique | 如果为True,则该字段在表中必须有唯一值,默认值是False。相当于SQL语句中的unique |
生成数据库迁移文件并且执行
python manage.py makemigrations
python manage.py migrate