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自定义表的名字。

默认名一般如下:
_
例: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'  #设置表名

然后进行数据迁移:



数据库:


你可能感兴趣的:(2020-04-18--Django8--管理器,元类)