字段类型
BooleanField:布尔字段,值为True或False。
NullBooleanField:支持Null、True、False三种值。
CharField(max_length=字符长度):字符串。
参数max_length表示最大字符个数。
TextField:大文本字段,一般超过4000个字符时使用。
IntegerField:整数。
DecimalField(max_digits=None, decimal_places=None):十进制浮点数。
参数max_digits表示总位数。
参数decimal_places表示小数位数。
FloatField:浮点数。
DateField[auto_now=False, auto_now_add=False]):日期。
参数auto_now表示每次保存对象时,自动设置该字段为当前时间,用于"最后一次修
改"的时间戳,它总是使用当前日期,默认为false。
参数auto_now_add表示当对象第一次被创建时自动设置当前时间,用于创建的时间
戳,它总是使用当前日期,默认为false。
参数auto_now_add和auto_now是相互排斥的,组合将会发生错误。
TimeField:时间,参数同DateField。
DateTimeField:日期时间,参数同DateField。
FileField:上传文件字段。
字段的约束
null:如果为True,表示允许为空,默认值是False。
blank:如果为True,则该字段允许为空白,默认值是False。
对比:null是数据库范畴的概念,blank是表单验证范畴的。
db_column:字段的名称,如果未指定,则使用属性的名称。
db_index:若值为True, 则在表中会为此字段创建索引,默认值是False。
default:默认值。
primary_key:若为True,则该字段会成为模型的主键字段,默认值是False,一般作为AutoField的选项使用。
unique:如果为True, 这个字段在表中必须有唯一值,默认值是False
字段查询
*F对象
两个字段的比较
*Q对象
两个字段之前或的关系
条件查询
查询
1、exact:表示判等。
模糊查询
2、contains:是否包含。
tartswith、endswith:以指定值开头或结尾。
空查询
3、isnull:是否为null。
范围查询
4、in:是否包含在范围内。
比较查询
5、gt、gte、lt、lte:大于、大于等于、小于、小于等于。
日期查询
6、year、month、day、week_day、hour、minute、second:对日期时间类型的属性进行运算。
聚合函数
Avg,Count,Max,Min,Sum,通常被定义在django.db.models中使用
注意aggregate的返回值是一个字典类型
{'聚合类小写__属性名':值}
使用count时一般不使用aggregate()过滤器。
注意count函数的返回值是一个数字。
查询集
查询集就是从数据库中获取的对象集合
返回查询集的过滤器
1 all()
返回模型类对应表的所有数据,返回值是QuerySet类型
2 filter()
返回满足条件的数据,返回值是QuerySet类型,参数可以写查询条件
3 exclude()
返回满足条件之外的数据(即:不满足条件的数据),返回值是QuerySet类型,参数可以 写查询条件
提示:相当于sql语句中where部分的not关键字
4 order_by()
对结果进行排序,返回值是QuerySet类型,参数可以写排序中的字段
返回单个值的过滤器
1 get()
返回单个满足条件的对象(有且只能有一条数据),参数可以是查询条件
如果未找到会引发"模型类.DoesNotExist"异常。
如果多条被返回,会引发"模型类.MultipleObjectsReturned"异常。
2 count()
返回当前查询结果的总条数,返回值是一个数字.
3 aggregate()
进行聚合操作,返回一个字典。
查询集两大特性
1、惰性查询:只有在实际使用查询集中的数据的时候,才会发生对数据库的真正查
询, 调用数据的情况包括迭代,序列化,与if合用
2、缓存
当使用的是同一个查询集时,第一次的时候会发生实际数据库的查询,然后把结果缓
存起来,之后再使用这个查询集时,使用的是缓存中的结果集
限制集查询
可以对一个查询集进行 取下标或切片 操作,等同于sql中的limit和offset子句。
不支持负数索引
网友评论