Django模型类定义

Django模型类定义

  • 模型类被定义在应用/models.py文件中

  • 模型类必须继承自Model类,位于包django.db.models中

  • 模型类演示例子图书-英雄数据模型定义

  • 将会演示,模型的定义,以及数据库的查询操作

    定义

    • 创建应用booktest, 在models.py文件中定义模型类

      from django.db import models
      #定义图书模型类BookInfo
      
      class BookInfo(models.Model):
          
          btitle = models.CharField(max_length=20, verbose_name='名称')
          
          bpub_date = models.DateField(verbose_name='发布日期')
          
          bread = models.IntegerField(default=0, verbose_name='阅读量')
          
          bcomment = models.IntegerField(default=0, verbose_name='评论量')
              
          is_delete = models.BooleanField(default=False, verbose_name='逻辑删除')
          
          
          class Meta:
              db_table = 'tb_bookds' #指明数据库的表名
              verbose_name = '图书'
              verbose_name_plural = verbose_name
            
          def __str__(self):
              """
              	定义每个数据对象的显示信息
              """
              return self.btitle
       class HeroInfo(models.Model):
          GENDER_CHOICES = (
              (0, 'male'),
              (1, 'female')
          )
          hname = models.CharField(max_length=20, verbose_name='名称')
          hgender = models.SmallIntegerField(choices=GENDER_CHOICES, default=0, verbose_name='性别')
          hcomment = models.CharField(max_length=200, null=True, verbose_name='描述信息')
          hbook = models.ForeignKey(BookInfo, on_delete=models.CASCADE, verbose_name='图书')  # 外键
          is_delete = models.BooleanField(default=False, verbose_name='逻辑删除')
              class Meta:
              db_table = 'tb_heros'
              verbose_name = '英雄'
              verbose_name_plural = verbose_name
          def __str__(self):
              return self.hname
          
      
  1. 数据库表名

    模型类如果未指明表名,Django默认以 小写app应用名_小写模型类名 为数据库表名。

    可通过db_table 指明数据库表名。

  2. 关于主键

    django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列。

    默认创建的主键列属性为id,可以使用pk代替,pk全拼为primary key。

  3. 属性命名限制
    • 不能是python的保留关键字。

    • 不允许使用连续的下划线,这是由django的查询方式决定的。

    • 定义属性时需要指定字段类型,通过字段类型的参数指定选项,语法如下:

      属性=models.字段类型(选项)
      
  4. 字段类型
类型说明
AutoField自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性
BooleanField布尔字段,值为True或False
NullBooleanField支持Null、True、False三种值
CharField字符串,参数max_length表示最大字符个数
TextField大文本字段,一般超过4000个字符时使用
IntegerField整数
DecimalField十进制浮点数, 参数max_digits表示总位数, 参数decimal_places表示小数位数
FloatField浮点数
DateField日期, 参数auto_now表示每次保存对象时,自动设置该字段为当前时间,用于"最后一次修改"的时间戳,它总是使用当前日期,默认为False; 参数auto_now_add表示当对象第一次被创建时自动设置当前时间,用于创建的时间戳,它总是使用当前日期,默认为False; 参数auto_now_add和auto_now是相互排斥的,组合将会发生错误
TimeField时间,参数同DateField
DateTimeField日期时间,参数同DateField
FileField上传文件字段
ImageField继承于FileField,对上传的内容进行校验,确保是有效的图片
  1. 选项
选项说明
null如果为True,表示允许为空,默认值是False
db_column字段的名称,如果未指定,则使用属性的名称
db_index若值为True, 则在表中会为此字段创建索引,默认值是False
default默认
primary_key若为True,则该字段会成为模型的主键字段,默认值是False,一般作为AutoField的选项使用
unique如果为True, 这个字段在表中必须有唯一值,默认值是False
  1. 外键

在设置外键时,需要通过on_delete选项指明主表删除数据时,对于外键引用表数据如何处理,在django.db.models中包含了可选常量:

  • CASCADE 级联,删除主表数据时连通一起删除外键表中数据
  • PROTECT 保护,通过抛出ProtectedError异常,来阻止删除主表中被外键应用的数据
  • SET_NULL 设置为NULL,仅在该字段null=True允许为null时可用

添加测试数据

insert into tb_books(btitle,bpub_date,bread,bcomment,is_delete) values
('射雕英雄传','1980-5-1',12,34,0),
('天龙八部','1986-7-24',36,40,0),
('笑傲江湖','1995-12-24',20,80,0),
('雪山飞狐','1987-11-11',58,24,0);

insert into tb_heros(hname,hgender,hbook_id,hcomment,is_delete) values
('郭靖',0,1,'降龙十八掌',0),
('黄蓉',1,1,'打狗棍法',0),
('黄药师',0,1,'弹指神通',0),
('欧阳锋',0,1,'蛤蟆功',0),
('梅超风',1,1,'九阴白骨爪',0),
('乔峰',0,2,'降龙十八掌',0),
('段誉',0,2,'六脉神剑',0),
('虚竹',0,2,'天山六阳掌',0),
('王语嫣',1,2,'神仙姐姐',0),
('令狐冲',0,3,'独孤九剑',0),
('任盈盈',1,3,'弹琴',0),
('岳不群',0,3,'华山剑法',0),
('东方不败',1,3,'葵花宝典',0),
('胡斐',0,4,'胡家刀法',0),
('苗若兰',1,4,'黄衣',0),
('程灵素',1,4,'医术',0),
('袁紫衣',1,4,'六合拳',0);
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值