zoukankan      html  css  js  c++  java
  • 2 Model层-模型成员

    1 类的属性

    • objects:是Manager类型的对象,用于与数据库进行交互
    • 当定义模型类时没有指定管理器,则Django会为模型类提供一个名为objects的管理器
    • 支持明确指定模型类的管理器
    class BookInfo(models.Model):
        ...
        books = models.Manager()
    • 当为模型类指定管理器后,django不再为模型类生成名为objects的默认管理器

    2.管理器Manager

      管理器是模型类Model的一个属性,用于完成数据库的交互映射  

    • 管理器是Django的模型进行数据库的查询操作的接口,Django应用的每个模型都拥有至少一个管理器
    • 自定义管理器类主要用于两种情况
      1. 更改默认查询器的结果
    
      2. 定义一个模型类的创建方法
    • 情况一:向管理器类中添加额外的方法:见下面“创建对象”中的方式二
    • 情况二:修改管理器返回的原始查询集:重写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()

     

    3.创建对象

    • 当创建对象时,django不会对数据库进行读写操作
    • 调用save()方法才与数据库交互,将对象保存到数据库中
    • 使用关键字参数构造模型对象很麻烦,推荐使用下面的两种之式
    • 说明: _init _方法已经在基类models.Model中使用,在自定义模型中无法使用,

      (1)方式一:在模型类中增加一个类方法

    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()
     

     

      (2)方式二:在自定义管理器中添加一个方法

    • 在管理器的方法中,可以通过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()
     

    #coding=utf-8
    from django.db import models
    
    # Create your models here.
    
    class BookInfoManager(models.Manager):
        """管理器"""
        def get_queryset(self):
            return super(BookInfoManager, self).get_queryset().filter(isDelete=False)
    
        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') # 别名
        bread = models.IntegerField(default=0)
        bcommet = models.IntegerField(null=True)   # 整数
        isDelete = models.BooleanField(default=False)
    
        class Meta:  # 元数据选项
            db_table = 'bookinfo'  # 默认表名字 booktest_BookInfo
            # ordering = ['id']  # 排序规则
    
        books1 = models.Manager()
        books2 = BookInfoManager()
    
        # def __init__(self):  # Model里面有__init__
        #     pass
    
        @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
    
    
    
    class HeroInfo(models.Model):
        """英雄信息表"""
        hname = models.CharField(max_length=10)
        hgender = models.BooleanField(default=True)
        hcontent = models.CharField(max_length=1000)
        isDelete = models.BooleanField(default=False)
        book = models.ForeignKey(BookInfo)     # 外键 一本书对应多个英雄
    Model文件

    4.实例的属性

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

    5.实例的方法

    • str (self):重写object方法,此方法在将对象转换成字符串时会被调用
    • save():将模型对象保存到数据表中
    • delete():将模型对象从数据表中删除
  • 相关阅读:
    既然来了,就要在这扎根
    vuejs 组件 移动端push 没有渲染页面
    cucumber——BDD的一个自动化测试的副产品
    Spock框架——单元测试框架
    Mockito——用于 Java 开发的模拟测试框架
    TestNG——开源自动化测试框架
    selenium/appium/airtest——UI测试工具
    rest-assured 使用指南——接口测试
    JUnit 4.1——單元測試框架
    二、面向對象(补充)
  • 原文地址:https://www.cnblogs.com/venicid/p/8280705.html
Copyright © 2011-2022 走看看