Django 中 models 用法及参数详解

一、 模型常用字段

01. models.AutoField

  • 自增列 (int(11))

  • 参数中必须填入 primary_key=True

  • 默认情况下 Django 会为 ORM 中定义的每一张表加上一个自增 ID 字段,并且用这个字段来做主键。Django 默认的行为就像这样:

    即不主动添加此 ID 字段 Django 会自动添加该自增字段

    class TestModel(models.Model):
        id = models.AutoField(primary_key=True)
    

    数据库层面对应的 SQL 语句如下:

    CREATE TABLE `myapp_testmodel` (
     `id` int(11) NOT NULL AUTO_INCREMENT,
     PRIMARY KEY (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    

注意
如果要显式的自定义一个自增列,必须设置 primary_key=True,否则会报错,即下面这种写法是不被允许的:

class TestModel(models.Model):
    tid = models.AutoField()

02. models.CharField

03. models.BooleanField

  • 布尔类型 tinyint(1)
  • 不能为空,可添加 Blank=True

04. models.ComaSeparatedIntegerField

  • 用逗号分割的数字 varchar
  • 继承 CharField,所以必须 max_length 参数

05. models.DateField

  • 日期类型 date
  • DateField.auto_now: 保存时自动设置该字段为现在日期,最后修改日期
  • DateField.auto_now_add: 当该对象第一次被创建是自动设置该字段为现在日期,创建日期

06. models.DateTimeField

  • 日期时间类型 datetime
  • DateField 的参数

07. models.DecimalField

  • 十进制小数类型 decimal
  • DecimalField.max_digits: 数字中允许的最大位数
  • DecimalField.decimal_places: 存储的十进制位数

08. models.EmailField

  • 带有检查 Email 合法性的 CharField

09. models.FloatField

  • 浮点类型 double

10. models.IntegerField

  • 整型 int

11. models.BigIntegerField

  • 长整型

12. models.GenericIPAddressField

  • 一个带有检查 IP地址合法性的 CharField

13. models.NullBooleanField

  • 允许为空的布尔类型

14. models.PositiveIntegerField

  • 正整数

15. models.PositiveSmallIntegerField

  • smallInteger

16. models.SlugField

  • 减号、下划线、字母、数字

17. models.SmallIntegerField

  • 数字 tinyintsmallintintbigint

18. models.TextField

  • 大文本。默认对应的 form 标签是 textarea

19. models.TimeField

  • 时间 HH:MM[:ss[.uuuuuu]]

20. models.URLField

  • 一个带有URL合法性校验的 CharField

21. models.BinaryField

  • 二进制
  • 存储二进制数据。不能使用 filter 函数获得 QuerySet

22. models.ImageField

  • 图片
  • ImageField.height_fieldImageField.width_field: 如果提供这两个参数,则图片将按提供的高度和宽度规格保存,该字段要求 Python Imaging 库 Pillow
  • 会检查上传的对象是否是一个合法图片

23. models.FileField

  • 文件
  • FileField.upload_to: 用于保存上传文件的本地文件系统路径,该路径由 MEDIA_ROOT 中设置

24. models.FilePathField

  • FilePathField.path: 文件的绝对路径,必填
  • FilePathField.match: 用于过滤路径下文件名的正则表达式,该表达式将用在文件名上(不包括路径)
  • FilePathField.recursive: TrueFalse,默认为 False,指定是否应包括所有子目录的路径。

二、 字段常用参数

01. null

  • 如果是 TrueDjango 会在数据库中将此字段的值置为 NULL,默认值是 False

02. blank

  • 如果为 TruedjangoAdmin 中添加数据时可允许空值,可以不填。如果为 False 则必须填。默认是 False
  • null 纯粹是与数据库有关系的;而 blank 是与页面必填项验证有关的

03. primary_key

  • 主键,对 AutoField 类型设置主键后,就会代替原来的自增 id 字段

04. auto_now

  • 自动创建-无论添加或修改,都是当前操作的时间

05. auto_now_add

  • 自动创建-永远是创建时的时间

06. choices

  • 一个二维的元组被用作 choices,如果这样定义,Djangoselect box 代替普通的文本框

07. max_length

  • 字段长度

08. default

  • 默认值

09. verbose_name

  • Admin 中字段的显示名称,如果不设置该参数时,则为属性名

10. db_column

  • 数据库中的字段名称

11. unique

  • 不允许重复

12. db_index

  • 数据库索引

13. editable

  • Admin 里是否可编辑

14. error_messages

  • 错误提示

15. auto_created

  • 自动创建

16. help_text

  • Admin 中提示帮助信息

17. validators

  • 验证器

18. upload-to

  • 文件上传时的保存上传文件的目录
  • 6
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值