• Django学习路34_models 文件创建数据表


    from django.db import models
    
    # Create your models here.
    class BookInfoManager(models.Manager):
        '''图书模型管理器类'''
        # 1.改变原有查询的结果集
        def all(self):
            # 1.调用父类的all方法,获取所有数据
            books = super().all() # QuerySet
            # 2.对books中的数据进行过滤
            books = books.filter(isDelete=False)
            # 返回books
            return books
    
        # 2.封装方法,操作模型类对应的数据表(增删改查)
        def create_book(self, btitle, bpub_date):
            '''添加一本图书'''
            # 1.创建一个图书对象
            # 获取self所在的模型类
            model_class = self.model
            book = model_class()
            # book = BookInfo()
            book.btitle = btitle
            book.bpub_date = bpub_date
            # 2.添加进数据库
            book.save()
            # 3.返回book
            return book
    
    
    # 一类
    # booktest2_bookinfo
    class BookInfo(models.Model):
        '''图书模型类'''
        # 图书名称
        btitle = models.CharField(max_length=20, db_column='title')
        # 图书名字唯一
        # btitle = models.CharField(max_length=20, unique=True, db_index=True)
        # 价格,最大位数为10,小数为2
        # bprice = models.DecimalField(max_digits=10, decimal_places=2)
        # 出版日期
        bpub_date = models.DateField()
        # bpub_date = models.DateField(auto_now_add=True) # 创建时间
        # bpub_date = models.DateField(auto_now=True) # 更新时间
        # 阅读量
        bread = models.IntegerField(default=0)
        # 评论量
        bcomment = models.IntegerField(default=0)
        # 删除标记
        isDelete = models.BooleanField(default=False)
    
        # book = models.Manager() # 自定一个Manager类对象,管理器对象
        objects = BookInfoManager() # 自定义一个BookInfoManager类的对象
    
        # @classmethod
        # def create_book(cls, btitle, bpub_date):
        #     '''添加一本图书'''
        #     # 创建一个cls类的对象
        #     obj = cls()
        #     obj.btitle = btitle
        #     obj.bpub_date = bpub_date
        #     # 添加进数据库
        #     obj.save()
        #     # 返回obj
        #     return obj
    
        class Meta:
            db_table = 'bookinfo' # 指定模型类对应表名
    
    
    
    # 多类
    class HeroInfo(models.Model):
        '''英雄人物模型类'''
        # 英雄名
        hname = models.CharField(max_length=20)
        # 性别
        hgender = models.BooleanField(default=False)
        # 备注
        hcomment = models.CharField(max_length=200, null=True, blank=False)
        # 关系属性
        hbook = models.ForeignKey('BookInfo',on_delete=True)
        # 删除标记
        isDelete = models.BooleanField(default=False)
    '''
    # 新闻类型类
    class NewsType(models.Model):
        # 类型名
        type_name = models.CharField(max_length=20)
        # 关系属性,代表类型下面的信息
        type_news = models.ManyToManyField('NewsInfo')
    
    # 新闻类
    class NewsInfo(models.Model):
        # 新闻标题
        title = models.CharField(max_length=128)
        # 发布时间
        pub_date = models.DateTimeField(auto_now_add=True)
        # 信息内容
        content = models.TextField()
        # 关系属性, 代表信息所属的类型
        # news_type = models.ManyToManyField('NewsType')
    
    # 员工基本信息类
    class EmployeeBasicInfo(models.Model):
        # 姓名
        name = models.CharField(max_length=20)
        # 性别
        gender = models.BooleanField(default=False)
        # 年龄
        age = models.IntegerField()
        # 关系属性,代表员工的详细信息
        employee_detail = models.OneToOneField('EmployeeDetailInfo')
    
    # 员工详细信息类
    class EmployeeDetailInfo(models.Model):
        # 联系地址
        addr = models.CharField(max_length=256)
        # 教育经历
        # 关系属性,代表员工基本信息
        # employee_basic = models.OneToOneField('EmployeeBasicInfo')
    '''
    
    class AreaInfo(models.Model):
        '''地区模型类'''
        # 地区名称
        atitle = models.CharField(max_length=20)
        # 关系属性,代表当前地区的父级地区
        aParent = models.ForeignKey('self', null=True, blank=True,on_delete=True)
    
        # class Meta:
        #     db_table = 'areas'

    2020-05-19

  • 相关阅读:
    搭建Go调试环境(LiteIDE)
    golang编译工具LiteIDE的调试使用方法(F5)
    Golang并发模型:轻松入门流水线FAN模式
    Golang并发中channel的分析
    需求设计说明书的重要性
    Chrome开发者工具详解-Elements、Console、Sources面板
    Chrome开发者工具详解(5)-Application、Security、Audits面板
    bzoj1216: [HNOI2003]操作系统
    bzoj1150: [CTSC2007]数据备份Backup
    bzoj1059: [ZJOI2007]矩阵游戏
  • 原文地址:https://www.cnblogs.com/hany-postq473111315/p/12920060.html
Copyright © 2020-2023  润新知