2020-04-18--Django8--管理器,元类

模型实例方法

  • str():在将对象转换成字符串时会被调用。
  • save():将模型对象保存到数据表中,ORM框架会转换成对应的insert或update语句。
  • delete():将模型对象从数据表中删除,ORM框架会转换成对应的delete语句。
#实例.方法()
books.save()

模型类的属性

属性objects:管理器,是models.Manager类型的对象,用于与数据库进行交互。

当没有为模型类定义管理器时,Django会为每一个模型类生成一个名为objects的管理器,自定义管理器后,Django不再生成默认管理器objects。

管理器Manager

管理器是Django的模型进行数据库操作的接口,Django应用的每个模型类都拥有至少一个管理器。Django支持自定义管理器类,继承自models.Manager。(也就是之前一直在用的objects对象(默认)。)


为模型类BookInfo定义管理器books语法如下:

class BookInfo(models.Model):
    ...
    books = models.Manager()

在原来的模型类中添加了管理器,Django就不会为我们创建objecs对象了,调用的时候会报错,用如下方式调用

#模型类.属性.方法()
BookInfo.books.all()

自定义管理器类主要用于两种情况:

  • 1.修改原始查询集,重写all()方法(改变查询的结果集)
  • 2.向管理器类中添加额外的方法,如向数据库中插入数据。
1.改变objects属性-->books属性

(1)我们的管理器定义在booktest/models.py中,定义类BookInfoManager:

#定义BookInfo的管理器
class BookInfoManager(models.Manager):
    pass
class BookInfo(models.Model):
    btitle = models.CharField(max_length=20)
    bpub_date = models.DateField()
    bread = models.IntegerField(default=0)
    bcomment = models.IntegerField(default=0)
    isDelete = models.BooleanField(default=False)
    #管理器对象实例(代替objects)
    books = BookInfoManager()

当再次在views中使用BookInfo.objects...时会报错,那么这时候必须使用:
BookInfo.books...


2.修改原始查询集--重写all()方法

业务场景:原始的all()方法是查询数据库中的全部小说,当某小说因为某种原因需要下架时,不能真删那,好不容易写的,我我们要做的是把他从用户界面取消显示,而不是真正的删除它在数据库中的信息。(也就是伪删除)这时候我们要在管理器中重写all()方法,这样的话我们的视图函数就不需要改变,也能够改变查询结果

#BookInfo的管理器
class BookInfoManager(models.Manager):
    #重写all()方法
    def all(self):
        #筛选出isDelete = 0的书
        return super.all().filter(isDelete=False)
class BookInfo(models.Model):
    btitle = models.CharField(max_length=20)
    bpub_date = models.DateField()
    bread = models.IntegerField(default=0)
    bcomment = models.IntegerField(default=0)
    isDelete = models.BooleanField(default=False)
    #管理器对象实例(代替objects)
    books = BookInfoManager()

验证:
我们把数据库中的‘雪山飞狐’的isDelete改为1,

>>> from booktest.models import *
>>> [book.btitle for book in BookInfo.books.all()]
['射雕英雄传', '天龙八部', '笑傲江湖']
#再把笑傲江湖的isdelete改为1,结果为:
>>> [book.btitle for book in BookInfo.books.all()]
['射雕英雄传', '天龙八部']
>>> quit()

3.创建自定义方法:

创建create_book方法,调用时直接将对象保存到数据库中

#BookInfo的管理器
class BookInfoManager(models.Manager):
    #重写all()方法
    def all(self):
        #筛选出isDelete = 0的书
        return super().all().filter(isDelete=False)

    def create_book(self, title, pub_date):
        # 调用此方法直接将对象保存到数据库
        book = self.model()      #获取模型类对象
        book.btitle = title
        book.bpub_date = pub_date
        book.bread = 0
        book.bcomment = 0
        book.isDelete = False
        book.save()         #保存
        return book

数据库:


元选项

Meta
在模型类中定义类Meta,用于设置元信息,如使用db_table自定义表的名字。

默认名一般如下:
<app_name>_<model_name>
例:booktest_bookinfo

当我们要改变表的名称时,要使用元选项:
在BookInfo模型类中添加如下内容,代码如下:

class BookInfo(models.Model):
    btitle = models.CharField(max_length=20)
    bpub_date = models.DateField()
    bread = models.IntegerField(default=0)
    bcomment = models.IntegerField(default=0)
    isDelete = models.BooleanField(default=False)
    #管理器对象实例(代替objects)
    books = BookInfoManager()
    #设置元选项
    class Meta:
        db_table='bookinfo'  #设置表名

然后进行数据迁移:



数据库:


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
禁止转载,如需转载请通过简信或评论联系作者。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351