其他分享
首页 > 其他分享> > Django框架基础知识07-常用查询及表关系的实现

Django框架基础知识07-常用查询及表关系的实现

作者:互联网

 

 

1.常用的模型字段类型 https://docs.djangoproject.com/en/2.1/ref/models/fields/#field-types

2.字段的常用参数 官方文档:https://docs.djangoproject.com/en/2.1/ref/models/fields/#field-options

3.常用查询 通过模型类上的管理器来构造QuerySet。

模型类上的管理器是啥? ​ 模型类.objects,<django.db.models.manager.Manager>实例

 

常用的查询方法:

 

常用的查询条件:

 

查找对象的条件的意思是传给以上方法的一些参数。相当于是SQL语句中的where语句后面的条件,语法为字段名__规则(是连着连个下划线哦)

常用的字段类型映射关系:

 

常用的字段类型:

  1. IntegerField : 整型,映射到数据库中的int类型。

  2. CharField: 字符类型,映射到数据库中的varchar类型,通过max_length指定最大长度。

  3. TextField: 文本类型,映射到数据库中的text类型。

  4. BooleanField: 布尔类型,映射到数据库中的tinyint类型,在使用的时候,传递True/False进去。如果要可以为空,则用NullBooleanField。

  5. DateField: 日期类型,没有时间。映射到数据库中是date类型,

    在使用的时候,可以设置DateField.auto_now每次保存对象时,自动设置该字段为当前时间。设置DateField.auto_now_add当对象第一次被创建时自动设置当前时间。

  6. DateTimeField: 日期时间类型。映射到数据库中的是datetime类型,

    在使用的时候,传递datetime.datetime()进去。

Field的常用参数:

primary_key: 指定是否为主键。

unique: 指定是否唯一。

null: 指定是否为空,默认为False。

blank: 等于True时form表单验证时可以为空,默认为False。

default: 设置默认值。

DateField.auto_now: 每次修改都会将当前时间更新进去,只有调用,QuerySet.update方法将不会调用。这个参数只是Date和DateTime以及TimModel.save()方法才会调用e类才有的。

DateField.auto_now_add: 第一次添加进去,都会将当前时间设置进去。以后修改,不会修改这个值

1.创建模型类

 

2.执行生成映射文件的命令后,查看数据表

 

3.插入数据.

 

4.查看插入的数据.

 

表关系的实现:

 

 

表关系的例子:

 

 

创建模型类:

 

外键和一对一关系的时候需要加on_delete选项,此参数为了避免两个表里的数据不一致问题,不然会报错!

一般使用CASCADE表示级联删除

 

查看数据库中创建的表:

写好模型类后,执行生成映射文件的命令.

 

执行完makemigrations和migrate的命令后,在数据库我们能看到5张表,其中多对多关系的ManyToManyField

方法自动生成了关系表.

标签:07,映射,fields,数据库,Django,objects,及表,类型,age
来源: https://www.cnblogs.com/winfun/p/10966806.html