重写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中使用matplotlib模块绘制数据图的示例
May 04 Python
基于进程内通讯的python聊天室实现方法
Jun 28 Python
Django框架中的对象列表视图使用示例
Jul 21 Python
Django 过滤器汇总及自定义过滤器使用详解
Jul 19 Python
opencv 获取rtsp流媒体视频的实现方法
Aug 23 Python
python 字典访问的三种方法小结
Dec 05 Python
keras 特征图可视化实例(中间层)
Jan 24 Python
TFRecord文件查看包含的所有Features代码
Feb 17 Python
python如何处理程序无法打开
Jun 16 Python
Python析构函数__del__定义原理解析
Nov 20 Python
python_tkinter事件类型详情
Mar 20 Python
Python线程池与GIL全局锁实现抽奖小案例
Apr 13 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环境配置 php5 mysql5 apache2 phpmyadmin安装与配置
2006/11/17 PHP
PHP 遍历文件实现代码
2011/05/04 PHP
PHP测试程序运行时间的类
2012/02/05 PHP
PHP管理内存函数 memory_get_usage()使用介绍
2012/09/23 PHP
php动态添加url查询参数的方法
2015/04/14 PHP
jquery 输入框数字限制插件
2009/11/10 Javascript
jsTree 基于JQuery的排序节点 Bug
2011/07/26 Javascript
jquery如何把参数列严格转换成数组实现思路
2013/04/01 Javascript
Json字符串转换为JS对象的高效方法实例
2013/05/01 Javascript
JS中判断null、undefined与NaN的方法
2014/03/26 Javascript
jquery 实现input输入什么div图层显示什么
2014/06/15 Javascript
通过jquery实现页面的动画效果(实例代码)
2016/09/18 Javascript
小程序开发基础之view视图容器
2018/08/21 Javascript
[04:52]DOTA2亚洲邀请赛附加赛 TOP10精彩集锦
2015/01/29 DOTA
[04:14]从西雅图到上海——玩家自制DOTA2主题歌曲应援TI9
2019/07/11 DOTA
python导出hive数据表的schema实例代码
2018/01/22 Python
python topN 取最大的N个数或最小的N个数方法
2018/06/04 Python
django2+uwsgi+nginx上线部署到服务器Ubuntu16.04
2018/06/26 Python
python matlibplot绘制多条曲线图
2021/02/19 Python
jupyter修改文件名方式(TensorFlow)
2020/04/21 Python
Django跨域请求原理及实现代码
2020/11/14 Python
python实现猜拳游戏项目
2020/11/30 Python
详解Open Folder as PyCharm Project怎么添加的方法
2020/12/29 Python
Python tkinter之ComboBox(下拉框)的使用简介
2021/02/05 Python
Banana Republic欧盟:美国都市简约风格的代表品牌
2018/05/09 全球购物
加拿大户外探险购物网站:SAIL
2020/06/27 全球购物
科室工作个人总结的自我评价
2013/10/29 职场文书
护理专业毕业生自荐信范文
2014/01/05 职场文书
表扬信格式
2014/01/12 职场文书
企业管理毕业生求职信范文
2014/03/07 职场文书
小学生操行评语
2014/04/22 职场文书
小学社会实践活动总结
2014/07/03 职场文书
大学生第一学年自我鉴定
2014/09/12 职场文书
2014年底个人工作总结
2015/03/10 职场文书
2015年度优秀员工推荐信
2015/03/23 职场文书
教师节班会开场白
2015/06/01 职场文书