模型实例方法
- 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' #设置表名
然后进行数据迁移:
数据库: