美文网首页
2019-02-23后端整理

2019-02-23后端整理

作者: 回忆在美也是曾经 | 来源:发表于2019-02-24 08:41 被阅读0次

    字段类型

    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后端整理

          本文链接:https://www.haomeiwen.com/subject/mlzpyqtx.html