2019-02-23后端整理

字段类型

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子句。

不支持负数索引

你可能感兴趣的:(2019-02-23后端整理)