Meta选项

Meta选项

在模型类内部定义Meta类(可选的,所有选项都不是必须的),可以配置模型的元数据,

例如:

1、如排序选项(ordering)

2、数据库表名(db_table)

3、人类可读的单复数名称(verbose_name 和verbose_name_plural)。

from django.db import models

class Person(models.Model):
    PRIORITY_CHOICES = [
        (0,'admin'),
        (1,'user'),
        (2,'visitor'),
    ]

    id=models.AutoField(primary_key=True)
    name=models.CharField(max_length=30,null=True)
    priority=models.IntegerField(choices=PRIORITY_CHOICES)
    create_time=models.DateTimeField(auto_now_add=True)

    class Meta:
        # 数据库中生成的表名称 默认 app名称 + 下划线 + 类名
        db_table='my_table'

        # 联合索引
        index_together = [
            ("priority", "create_time"),
        ]

        # 建立联合索引推荐使用下面这种
        indexes = [
            models.Index(fields=["priority", "create_time"]), # 联合索引
            models.Index(fields=['priority'], name='priority_idx'), # 单独的索引
            # 关于索引名称:如果没有提供name,Django将自动生成一个索引名称。 为了兼容不同的数据库,索引名称不能超过30个字符,不能以数字(0-9)或下划线(_)开头。
        ]

        # 联合唯一索引
        unique_together = (("name", "priority"),)

        # 执行Person.objects.all()
        # 会先按照权限priority字段降序排,权限相同则按照创建时间create_time字段升序排
        ordering = ('-priority','create_time') 

        # 主界面的表名会默认加s,我们可以自己指定,如下
        verbose_name_plural = "table1"

        # admin中详情页显示的表名称
        verbose_name = '表1'

        # 执行Person.objects.latest()
        # 会先按照权限priority字段降序排列,权限相同则按照id字段升序排列,然后取最后一个
        get_latest_by=['create_time','id'] 

    def __str__(self):
        return '%s:%s:%s' %(self.name,self.priority,self.create_time)
暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇

You cannot copy content of this page