django模型类生成id字段,元类属性,抽象模型类

db_table指定映射数据库中的表名;
ordering 对检索结果指定默认排序
verbose_name指定在admin管理界面中显示中文,verbose_name表示单数形式的显示;
verbose_name_plural表示复数形式的显示;
中文的表名没有单复数区别,但是不设置verbose_name_plural = verbose_name,在管理界面中显示的表名后面会有字母s

class A(models.Model):

    class Meta:
        db_table = 'aaa' # 映射到数据库的表名 默认表名是 appname_book
        ordering = ['-pub_date', 'id'] # 排序 可通过多个字段排序 倒序添加"-"即可
        verbose_name = 'A'
        verbose_name_plural = verbose_name

中文的表名没有单复数区别,但是不设置verbose_name_plural = verbose_name,在管理界面中显示的表名后面会有字母s

字段中verbose_name也是设置在admin管理界面指定显示字段名

class ProductSKU(BaseModel):
    PRODUCT_STATUS = (
        (0, '下线'),
        (1, '上线')
    )
    name = models.CharField(max_length=50, verbose_name='商品名称')
    desc = models.CharField(max_length=100, verbose_name='商品简介')
    price = models.DecimalField(max_digits=10, decimal_places=2, verbose_name='商品价格')
    unite = models.CharField(max_length=20, verbose_name='单位')
    image = models.ImageField(upload_to='products', verbose_name='商品图片')
    inventory = models.IntegerField(default=1, verbose_name='库存')
    sales = models.IntegerField(default=0, verbose_name='销量')
    status = models.SmallIntegerField(default=1,choices=PRODUCT_STATUS, verbose_name='商品状态')
    type = models.ForeignKey(ProductCategory, verbose_name='所属分类', on_delete=models.CASCADE)
    products = models.ForeignKey(Products, verbose_name='商品SPU', on_delete=models.CASCADE)

django 模型类会自动生成表的id字段

表结构:

在这里插入图片描述
在元类指定属性abstract = True,该类就为抽象模型类

class BaseModel(models.Model):
    '''所有模型类的抽象基类'''
    create_date = models.DateTimeField(auto_now_add=True, verbose_name='创建时间')
    update_date = models.DateTimeField(auto_now=True, verbose_name='更新时间')
    is_delete = models.BooleanField(default=True, verbose_name='删除标记')

    class Meta:
        abstract = True
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值