(模型三)模型成员介绍

类的属性

  • objects:是Manager类型(django中已经定义好的,ORM的核心)的对象,用于与数据库进行交互
  • 当定义模型类时没有指定管理器,则Django会为模型类提供一个名为objects的管理器
  • 支持明确指定模型类的管理器
class BookInfo(models.Model):
    ...
    books = models.Manager()   # 自己写意义不大,一般都用objects,如果自己这样写了,默认的objects管理器就没了
  • 当为模型类指定管理器后,django不再为模型类生成名为objects的默认管理器

管理器Manager

  • 管理器是Django的模型进行数据库的查询操作的接口,Django应用的每个模型都拥有至少一个管理器
  • 自定义管理器类主要用于两种情况
  • 情况一:向管理器类中添加额外的方法:见下面“创建对象”中的方式二
  • 情况二:修改管理器返回的原始查询集:重写get_queryset()方法
class BookInfoManager(models.Manager):
    def get_queryset(self):
        return super(BookInfoManager, self).get_queryset().filter(isDelete=False)
class BookInfo(models.Model):
    ...
    books = BookInfoManager()

创建对象

  • 当创建对象时,django不会对数据库进行读写操作
  • 调用save()方法才与数据库交互,将对象保存到数据库中
  • 使用关键字参数构造模型对象很麻烦,推荐使用下面的两种之式
  • 说明: _init _方法已经在基类models.Model中使用,在自定义模型中无法使用,
  • 方式一:在模型类中增加一个类方法
class BookInfo(models.Model):
    ...
    @classmethod
    def create(cls, title, pub_date):
        book = cls(btitle=title, bpub_date=pub_date)
        book.bread=0
        book.bcommet=0
        book.isDelete = False
        return book
引入时间包:from datetime import *
调用:book=BookInfo.create("hello",datetime(1980,10,11));
保存:book.save()

例如:
from django.db import models
class BookInfo(models.Model):
    btitle = models.CharField(max_length=20)
    bpub_date = models.DateTimeField(db_column='pub_date')  # db_column:字段的名称,如果未指定,则使用属性的名称
    bread = models.IntegerField(default=0)  # 阅读量
    bcommet = models.IntegerField(null=False)  # null=False表示不能为空
    isDelete = models.BooleanField(default=False)

    class Meta:
        db_table = 'bookinfo'  # 默认为booktest_bookinfo

    @classmethod
    def create(cls, btitle, bpub_date):
        b = BookInfo()
        b.btitle = btitle
        b.bpub_date = bpub_date
        b.bread = 0
        b.bcommet = 0
        b.isDelete = False
        return b

进入shell

python manage.py shell

查看数据库是否改变


  • 方式二:在自定义管理器中添加一个方法(推荐用)
  • 在管理器的方法中,可以通过self.model来得到它所属的模型类
class BookInfoManager(models.Manager):
    def create_book(self, title, pub_date):
        book = self.model()
        book.btitle = title
        book.bpub_date = pub_date
        book.bread=0
        book.bcommet=0
        book.isDelete = False
        return book

class BookInfo(models.Model):
    ...
    books = BookInfoManager()
调用:book=BookInfo.books.create_book("abc",datetime(1980,1,1))
保存:book.save()

例如:
from django.db import models


class BookInfoManager(models.Manager):
    def create(cls, btitle, bpub_date):
        b = BookInfo()
        b.btitle = btitle
        b.bpub_date = bpub_date
        b.bread = 0
        b.bcommet = 0
        b.isDelete = False
        return b


class BookInfo(models.Model):
    btitle = models.CharField(max_length=20)
    bpub_date = models.DateTimeField(db_column='pub_date')  # db_column:字段的名称,如果未指定,则使用属性的名称
    bread = models.IntegerField(default=0)  # 阅读量
    bcommet = models.IntegerField(null=False)  # null=False表示不能为空
    isDelete = models.BooleanField(default=False)

    class Meta:
        db_table = 'bookinfo'  # 默认为booktest_bookinfo
    book1 = BookInfoManager()  # 作为模型类的属性用  管理器是模型类中的属性,用于将对象与数据映射

同样进入shell

from booktest.models import BookInfo

from datetime import datetime

b = BookInfo.book1.create('a',datetime(2019,1,5))   (book1是管理器)方法1中是:b=BookInfo.create('gt',datetime(2019,1,5))

b.save()

 
  • 在方式二中,可以调用self.create()创建并保存对象,不需要再手动save()
class BookInfoManager(models.Manager):
    def create_book(self, title, pub_date):
        book = self.create(btitle = title,bpub_date = pub_date,bread=0,bcommet=0,isDelete = False)
        return book

class BookInfo(models.Model):
    ...
    books = BookInfoManager()
调用:book=Book.books.create_book("abc",datetime(1980,1,1))
查看:book.pk

实例的属性

  • DoesNotExist:在进行单个查询时,模型的对象不存在时会引发此异常,结合try/except使用

实例的方法

  • str (self):重写object方法,此方法在将对象转换成字符串时会被调用
  • save():将模型对象保存到数据表中
  • delete():将模型对象从数据表中删除
 
posted @ 2019-01-05 10:38  Miss-Gao  阅读(160)  评论(0编辑  收藏  举报