Django教程:ORM 常用字段和参数

2022-09-2511:39:10后端程序开发Comments730 views字数 3790阅读模式

一、models中的常用字段类型


字段类型文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

类型说明
AutoField自动增长的 IntegerField,通常不用指定,不指定时Django会自动创建属性名为 id 的自动增长属性。
BooleanField布尔字段,值为True 或 False
NullBooleanField支持Null、True、False三种值
CharField字符串,参数max_length表示最大字符个数,对应mysql中的varchar。
TextField大文本字段,一般大段文本(超过4000个字符)才使用。
IntegerField整数
BigIntegerField长整型(有符号的)
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,对上传的内容进行校验,确保是有效的图片。
EmailField字符串类型,和邮箱相关

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

二、约束选项


选项说明
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。
max_length最大字符长度
verbose_name对应的名字,注释
max_digits数字允许的最大位数
decimal_places小数的最大位数
to设置关联的表
to_field设置关联的字段
db_constraint是否创建外键约束,默认True
related_name修改正向查询的字段名,之后就可以使用修改后的字段名,类似于起别名
on_delete当删除关联表中的数据时,当前表与其关联的行的行为

注意:null 是数据库范畴的概念,blank 是表单验证范畴的。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

外键文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

在设置外键时,需要通过 on_delete 选项指明主表删除数据时,对于外键引用表数据如何处理,在django.db.models中包含了可选常量:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

  • CASCADE 级联操作,当主表中被连接的一条数据删除时,从表中所有与之关联的数据同时被删除
  • PROTECT 当主表中的一行数据删除时,由于从表中相关字段是受保护的外键,所以都不允许删除
  • SET_NULL 当主表中的一行数据删除时,从表中所有与之关联的数据的相关字段设置为null,此时注意定义外键时,这个字段必须可以允许为空
  • SET_DEFAULT 当主表中的一行数据删除时,从表中所有相关的数据的关联字段设置为默认值,此时注意定义外键时,这个外键字段应该有一个默认值
  • DO_NOTHING 什么都不做,一切都看数据库级别的约束,注数据库级别的默认约束为RESTRICT,这个约束与django中的models.PROTECT相似
  • SET() 当主表中的一条数据删除时,从表中所有的关联数据字段设置为SET()中设置的值,与models.SET_DEFAULT相似,只不过此时从表中的相关字段不需要设置default参数
def func():
    return 10

class MyModel(models.Model):
    user = models.ForeignKey(
        to = "User",
        to_field = "id",
        on_delete = models.SET(func)
    )

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

三、常用查询


返回QuerySet对象文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

  • all()     查询所有结果。
  • filter() 它包含了与所给筛选条件相匹配的对象。
  • exclude()   排除在外,它包含了与所给筛选条件不匹配的对象。
  • order_by() 对查询结果排序,默认升序/(-字段)降序。
  • reverse()    对查询结果反向排序,前提是数据已经排序过了order_by()。
  • distinct()    从返回结果中剔除重复纪录。

返回对象文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

  • get()  返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。
  • first() 返回第一条记录
  • last()  返回最后一条记录

返回布尔值文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

  • exists() 如果QuerySet包含数据,就返回True,否则返回False。

返回数字文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

  • count() 统计当前数据的个数。

返回QuerySet文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

  • values() 返回一个ValueQuerySet,一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列。
  • values_list() 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列。

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

四、双下划线


filter里是不能写逻辑运算符的,而是给定了一个特定的方法去提供逻辑查询,那就是双下划线。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

返回值 = models.User.objects.filter(字段__contains = '条件')
方法功能
字段__gt大于
字段__lt小于
字段__gte大于等于
字段__lte小于等于
字段__in成员运算、在什么里
字段__range范围查询
字段__contains模糊查询,区分大小写
字段__icontains模糊查询,忽略大小写
字段__startswith匹配开头
字段__endswith匹配结尾
字段__regex正则表达式
字段__year按照年份筛选数据
字段__month按照月份筛选数据
字段__day按照天筛选数据

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

五、自定义char类型


Django中的CharField对应的MySQL数据库中的varchar类型。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

没有设置对应char类型的字段,但是Django允许自定义新的字段,对应于数据库的char类型。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

自定义字段在实际项目应用中可能会经常用到,需要对它留个印象!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

from django.db import models

class MyCharField(models.Field):
    '''
    自定义的 char类型 的字段类
    '''
    def __init__(self, max_length, *args **kwargs):
        self.max_length = max_length
        # 关键字方式传值
        super().__init__(max_length = max_length, *args, **kwargs)

    def db_type(self, connection):
        '''
        数据类型约束条件,max_length 指定的值
        :param connection:
        :return:
        '''
        return 'char(%s)' % self.max_length
    
# 自定义字段使用
class MyModel(models.Model):
    nid = models.AutoField(primary_key = True)
    title = models.CharField(max_length = 32)
    mychar = MyCharField(max_length=16, null = True)

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

六、字段合集


字段合集

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

七、ORM字段与MySQL字段对应关系


ORM字段与MySQL字段对应关系

 文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

八、Django 终端打印SQL语句


如果你想知道你对数据库进行操作时,Django 内部到底是怎么执行它的SQL语句时可以加下面的配置来查看。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

在Django 项目的 settings.py 文件中,在最后复制粘贴如下代码。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'console':{
            'level':'DEBUG',
            'class':'logging.StreamHandler',
        },
    },
    'loggers': {
        'django.db.backends': {
            'handlers': ['console'],
            'propagate': True,
            'level':'DEBUG',
        },
    }
}

配置好之后,再执行任何对数据库进行操作的语句时,会自动将 Django 执行的 SQL 语句打印到终端上。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

补充:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html

  • 除了配置外,还可以通过 .query 即可查看查询语句。
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/28020.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/bc/28020.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定