重写django的model下的objects模型管理器方式


Posted in Python onMay 15, 2020

django自定义管理器和model的继承

在我写代码时建立的很多数据库需要一些共同的字段,比如is_active, create_time这些字段,所以可以建立一个基类model

模型的继承

我们可以充分利用oop特性,建立一个基类model,以后所有的model都继承这个类, 就不用在每个类都额外添加字段

class BaseModel(models.Model):
  is_active = models.BooleanField(default=True)
  create_time = models.DateTimeField()

  class Meta:
   '''
   指定这个类是一个抽象模型类, 这个模型就不会被生成表
   '''
    abstract = True 
  
class ChildModel(BaseModel):
  name = models.CharField(max_length=10)
  age = models.PositiveIntegerField()
    
  class Meta:
    '''
    meta属性可以重写, 不重写的话也会继承基类meta
    '''
    verbose_name = '子模型'

重写Django的model.objects

当我们使用model.objects.filter()时,经常会过滤掉is_active=False的,但是这样我们每个 filter(is_active=True)都需要这样写,那我们能不能重写掉这个filter方法, 让他每次可以自己过滤掉,这里我们可以看一下django的源码

# 这里源码我就不拉出来了, 我们可以看到django是set了个objects属性, 这个属性对应是一个类的实例对象

class Manager(BaseManager.from_queryset(QuerySet)):
'''
objects 是这个类的实例对象, 这个类我们可以看到他其实继承了 QuerySet类里的方法,
 所以我们可以直接重写个这个类方法,并重写filter方法
'''
  def filter(self, *args, **kwargs):
    """
    我们可以看到 QuerySet里的filter方法和exclude方法都是调用了这个方法, 这个方法的内部实现可
    以自己看一看,就是用的kwargs里的参数
    """
    return self._filter_or_exclude(False, *args, **kwargs)

class MyManager(models.Manager):
  
  def filter(self, *args, **kwargs):
  '''
  源代码的filter函数是有返回值的,所以我们将super出来的结果返回出去,我们只需要在kwargs中增加个参数就行
  '''
    if not kwargs.get('is_active', True): # 如果需要查看所有数据,
      kwargs['is_active'] = False
    return super(AddressManager, self).filter(*args, **kwargs)

# 最后我们在我们的ChildModel下将objects对象赋值为MyManager的实例对象就可以使用了
# 我们可以将这个objects写在基类里面,这样所有的model就可以都会有这个方法,具体怎么使用视情况而定

class ChildModel(models.Model):
  objects = MyManager()

模型类也是可以多继承的,如果有特殊的用法可以具体百度或Google一下, 这里只是个简单的引入面向对象的概念,我们很多地方可以用继承框架已有的类并重写类中的方法,是我们的代码更加pythonic

补充知识:Django中的Model中的字段属性和选项

字段类型:

autoField:一个根据实际ID自动增长的IntegerField,通常不指定,如果不指定,一个主键字段将自动添加到模型中

CharField(max_length=字符长度):字符串,默认的表彰样式是TextInput

TextField:大文本字段,一般超过4000时使用,默认的表单控件是Textarea

IntegerField:整数

DecimalField(max_digits=None, decimal_places=None): 使用Python的Decimal实例表示的十进制浮点数

参数说明: DecimalField.max_digits----位数总数
DecimalField.decimal_places---小数点后的数字位置

FloatField: 使用Python的float实例来表示的浮点数

BooleanField:True/False 字段,此字段的默认表彰控制是CheckboxInput

NullBooleanField:支持 Null, True, False 三种值

DateField([auto_now=False, auto_now_add=False]):使用Python的datetime.date实例表示的日期

参数说明:
DateField.auto_now
每次保存对象时,自动设置该字段为当前时间,用于“最后一次修改”
的时间戳,它总是使用当前日期,默认为 False

DateField.auto_now_add

当前对象第一次被创建时自动设置当前时间,用于创建的时间戳,

它总是使用当前日期,默认为 False

说明
该字段默认对应的表单控件是一个TextInput.在管理员站点添加了一个
JavaScript写的日历控件,和一个“Today”的快捷按钮,包含了一个额外
的invalid_date错误消息键
注意
auto_now_add, auto_now, and default 这些设置是相互排斥的,他们之间
的任何组合将会发生错误的结果

TimeField: 使用Python的datetime.time实例表示的时间,参数同DateField

DateTimeField: 使用Python的datetime, datetime实例表示的日期和时间,参数同DateField

FileField: 一个上传文件的字段

ImageField:继承了FileField的所有属性和方法,但对上传的对象进行校验,确保它是一个有效的image

字段选项

概述:通过字段选项,可以实现对字段的约束, 在字段对象中通过关键字参数指定

null:如果为True,Django将空值以NULL存储在数据库中,默认值为False

blanke:如果为True,则该字段允许为空白,默认值为False

注意: null是数据库范畴的概念,blank是表彰验证范畴的概念

db_column:字段的名称,如果未指定,则使用属性的名称

db_index:若值为 True,则在表中会为此字段创建索引

default: 默认值

primary_key: 若为 True,则该字段会成为模型的主键字段

unique:如果为 True,这个字段在表中必须有唯一值

注意:在生成迁移文件之后如果修改的参数不影响表结构,则不用重新生成迁移文件。(default,blank 不影响表的结构。不用重新生成迁移文件)

关系类型

分类:

ForeignKey:一对多,将字段定义在多的端中

ManyToManyField:多对多,将字段定义在两端中

OneToOneField:一对一,将字段定义在任意一端中

(1)用一访问多:格式: 对象.模型类小写_set

示例: grade.students_set

(2)用一访问一:格式:对象.模型类小写

示例: grade.studnets

(3)访问id:格式:对象.属性_id

例子:btitle = models.CharField(max_length=20,db_column=‘title',unique=‘true')

以上这篇重写django的model下的objects模型管理器方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python学习教程之常用的内置函数大全
Jul 14 Python
Python切片工具pillow用法示例
Mar 30 Python
解决python3爬虫无法显示中文的问题
Apr 12 Python
python和shell监控linux服务器的详细代码
Jun 22 Python
关于python写入文件自动换行的问题
Jun 23 Python
python逆序打印各位数字的方法
Jun 25 Python
python实现将多个文件分配到多个文件夹的方法
Jan 07 Python
75条笑死人的知乎神回复,用60行代码就爬完了
May 06 Python
python实现自动化报表功能(Oracle/plsql/Excel/多线程)
Dec 02 Python
python如何把字符串类型list转换成list
Feb 18 Python
40行Python代码实现天气预报和每日鸡汤推送功能
Feb 27 Python
python开发一款翻译工具
Oct 10 Python
Python基于pip实现离线打包过程详解
May 15 #Python
Django在Model保存前记录日志实例
May 14 #Python
django 连接数据库出现1045错误的解决方式
May 14 #Python
Django ORM filter() 的运用详解
May 14 #Python
Django设置Postgresql的操作
May 14 #Python
numpy矩阵数值太多不能全部显示的解决
May 14 #Python
使用python采集Excel表中某一格数据
May 14 #Python
You might like
PHP preg_match实现正则表达式匹配功能【输出是否匹配及匹配值】
2017/07/19 PHP
PHP面向对象五大原则之依赖倒置原则(DIP)详解
2018/04/08 PHP
JavaScript 类似flash效果的立体图片浏览器
2010/02/08 Javascript
JavaScript 设计模式 富有表现力的Javascript(一)
2010/05/26 Javascript
改善用户体验的五款jQuery插件分享
2011/05/22 Javascript
基于jquery可配置循环左右滚动例子
2011/09/09 Javascript
JavaScript内核之基本概念
2011/10/21 Javascript
jquery实现加载等待效果示例
2013/09/25 Javascript
Extjs表单常见验证小结
2014/03/07 Javascript
使用jquery animate创建平滑滚动效果(可以是到顶部、到底部或指定地方)
2014/05/27 Javascript
javascript操作select元素实例分析
2015/03/27 Javascript
jQuery中closest和parents的区别分析
2015/05/07 Javascript
jQuery+Pdo编写login登陆界面
2016/08/01 Javascript
JavaScript自定义分页样式
2017/01/17 Javascript
vue2实现数据请求显示loading图
2017/11/28 Javascript
Vue如何实现响应式系统
2018/07/11 Javascript
对angular2中的ngfor和ngif指令嵌套实例讲解
2018/09/12 Javascript
详解基于electron制作一个node压缩图片的桌面应用
2019/01/29 Javascript
小程序如何写动态标签的实现方法
2020/02/05 Javascript
js实现动态时钟
2020/03/12 Javascript
Python中解析JSON并同时进行自定义编码处理实例
2015/02/08 Python
浅谈pandas中shift和diff函数关系
2018/04/08 Python
python删除字符串中指定字符的方法
2018/08/13 Python
在Python中append以及extend返回None的例子
2019/07/20 Python
Python 矩阵转置的几种方法小结
2019/12/02 Python
python单向循环链表原理与实现方法示例
2019/12/03 Python
python连接mysql有哪些方法
2020/06/24 Python
解决keras GAN训练是loss不发生变化,accuracy一直为0.5的问题
2020/07/02 Python
Hotels.com台湾:饭店订房网
2017/09/06 全球购物
软件测试工程师面试问题精选
2016/10/28 面试题
小学一年级学生评语
2014/04/22 职场文书
小学校园文化建设汇报材料
2014/08/19 职场文书
升学宴答谢词
2015/01/05 职场文书
《小乌鸦爱妈妈》教学反思
2016/02/19 职场文书
2019财务毕业实习报告
2019/06/27 职场文书
虚拟机linux端mysql数据库无法远程访问的解决办法
2021/05/26 MySQL