django模型:字段和选项

https://blog.csdn.net/iloveyin/article/details/44852645
一、常用字段
1、字段类型
使用时需要引入django.db.models包,字段类型如下
AutoField:自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性
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:上传文件字段
ImageField:继承于FileField,对上传的内容进行校验,确保是有效的图片

2、关系字段类型
关系型数据库的关系包括三种类型:
ForeignKey:一对多,将字段定义在多的一端中
ManyToManyField:多对多,将字段定义在两端中
OneToOneField:一对一,将字段定义在任意一端中
可以维护递归的关联关系,使用'self'指定,详见“关联对象”

二、常用选项
1、选项
通过选项实现对字段的约束,选项如下:
max_length:为CharField型字段设置最大长度。
null:如果为True,表示允许为空,默认值是False
default:默认值

db_column:string 值,指定当前列在数据库中的名字,不设置,将自动采用model字段名;

verbose_name:设置此字段在admin界面上的显示名称。(这个功能和list_display属性类似了,优先显示verbose_name)

blank:如果为True,则该字段允许为空白,默认值是False
对比:null是数据库范畴的概念,blank是表单验证证范畴的
db_column:字段的名称,如果未指定,则使用属性的名称
db_index:若值为True, 则在表中会为此字段创建索引,默认值是False
primary_key:若为True,则该字段会成为模型的主键字段,默认值是False,一般作为AutoField的选项使用
unique:如果为True, 这个字段在表中必须有唯一值,默认值是False

2、元选项

(1)修改表名

数据表的默认名称为
<app_name>_<model_name>
例:
booktest_bookinfo
在模型类中定义类Meta,用于设置元信息,如使用db_table自定义表的名字

from django.db import models


class TbPassage234(models.Model):
    title = models.CharField(max_length=225)
    author = models.CharField(max_length=50,null=True,verbose_name='姓 名')
    pubtime = models.DateTimeField(null=True)
    sort = models.CharField(max_length=50,null=True)
    content = models.TextField(null=True)
    parse_time = models.DateTimeField(null=True,max_length=0)
    url_path = models.CharField(max_length=225,null=True)
    level_id = models.IntegerField(null=True)
    isDelete = models.BooleanField(default=False)#逻辑删除
    
    class Meta:#元类
        db_table = 'tb_passage234' #自定义表名

  

(2)修改字段名、设置打印显示名称

# 定义图书模型类BookInfo
class BookInfo(models.Model):
    btitle = models.CharField(max_length=20)  # 图书名称
    bpub_date = models.DateField()  # 发布日期
    bread = models.IntegerField(default=0)  # 阅读量
    bcommet = models.IntegerField(default=0)  # 评论量
    isDelete = models.BooleanField(default=False, db_column="bisDelete")  # 逻辑删除。修改字段名称。字段名isDelete修改为bisDelete

    class Meta:  # 元信息类
        db_table = 'bookinfo'  # 修改表的名称。表名booktest_bookinf修改为bookinfo

    def __str__(self):
        return self.btitle   # 打印时显示名称

  

清空迁移操作
https://blog.csdn.net/jianjianblog/article/details/52772591

原文地址:https://www.cnblogs.com/andy9468/p/8810059.html