django模型动态修改参数,增加 filter 字段的方式


Posted in Python onMarch 16, 2020

我就废话不多说啦,还是直接看代码吧!

kwargs = {
# 动态查询的字段
}
 
# 选择deleted_datetime为空的记录
if exclude_deleted:
kwargs[ 'deleted_datetime__isnull' ] = True
 
# 选择特的category
if category is not None:
kwargs[ 'category' ] = category
 
# 特定的用户
if current_user_only:
kwargs[ 'user' ] = current_user
 
# 根据标题查询
if title_search_query != '':
kwargs[ 'title__icontains' ] = title_search_query
 
# 应用所有的查询
entries = Entry.objects.filter( **kwargs )
# 打印出所有的结果检查
print entries

用这种方式,在Q object 方式下,是有问题的,要采用如下方式:

kwargs = { 'deleted_datetime__isnull': True }
args = ( Q( title__icontains = 'Foo' ) | Q( title__icontains = 'Bar' ) )
entries = Entry.objects.filter( args, **kwargs )

补充知识:Django模型系统的常用字段和字段参数

常用字段

AutoField:int自增列,必须填入参数 primary_key=True。当model中如果没有自增列,则自动会创建一个列名为id的列。

IntegerField:一个整数类型,范围在 -2147483648 to 2147483647。

CharField:字符类型,必须提供max_length参数, max_length表示字符长度

DateField:日期字段,日期格式 YYYY-MM-DD,相当于Python中的datetime.date()实例。

DateTimeField:日期时间字段,格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ],相当于Python中的datetime.datetime()实例。

所有字段合集

AutoField(Field)
    - int自增列,必须填入参数 primary_key=True
 
  BigAutoField(AutoField)
    - bigint自增列,必须填入参数 primary_key=True
 
    注:当model中如果没有自增列,则自动会创建一个列名为id的列
    from django.db import models
 
    class UserInfo(models.Model):
      # 自动创建一个列名为id的且为自增的整数列
      username = models.CharField(max_length=32)
 
    class Group(models.Model):
      # 自定义自增列
      nid = models.AutoField(primary_key=True)
      name = models.CharField(max_length=32)
 
  SmallIntegerField(IntegerField):
    - 小整数 -32768 ~ 32767
 
  PositiveSmallIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField)
    - 正小整数 0 ~ 32767
  IntegerField(Field)
    - 整数列(有符号的) -2147483648 ~ 2147483647
 
  PositiveIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField)
    - 正整数 0 ~ 2147483647
 
  BigIntegerField(IntegerField):
    - 长整型(有符号的) -9223372036854775808 ~ 9223372036854775807
 
  BooleanField(Field)
    - 布尔值类型
 
  NullBooleanField(Field):
    - 可以为空的布尔值
 
  CharField(Field)
    - 字符类型
    - 必须提供max_length参数, max_length表示字符长度
 
  TextField(Field)
    - 文本类型
 
  EmailField(CharField):
    - 字符串类型,Django Admin以及ModelForm中提供验证机制
 
  IPAddressField(Field)
    - 字符串类型,Django Admin以及ModelForm中提供验证 IPV4 机制
 
  GenericIPAddressField(Field)
    - 字符串类型,Django Admin以及ModelForm中提供验证 Ipv4和Ipv6
    - 参数:
      protocol,用于指定Ipv4或Ipv6, 'both',"ipv4","ipv6"
      unpack_ipv4, 如果指定为True,则输入::ffff:192.0.2.1时候,可解析为192.0.2.1,开启此功能,需要protocol="both"
 
  URLField(CharField)
    - 字符串类型,Django Admin以及ModelForm中提供验证 URL
 
  SlugField(CharField)
    - 字符串类型,Django Admin以及ModelForm中提供验证支持 字母、数字、下划线、连接符(减号)
 
  CommaSeparatedIntegerField(CharField)
    - 字符串类型,格式必须为逗号分割的数字
 
  UUIDField(Field)
    - 字符串类型,Django Admin以及ModelForm中提供对UUID格式的验证
 
  FilePathField(Field)
    - 字符串,Django Admin以及ModelForm中提供读取文件夹下文件的功能
    - 参数:
        path,           文件夹路径
        match=None,        正则匹配
        recursive=False,      递归下面的文件夹
        allow_files=True,     允许文件
        allow_folders=False,    允许文件夹
 
  FileField(Field)
    - 字符串,路径保存在数据库,文件上传到指定目录
    - 参数:
      upload_to = ""   上传文件的保存路径
      storage = None   存储组件,默认django.core.files.storage.FileSystemStorage
 
  ImageField(FileField)
    - 字符串,路径保存在数据库,文件上传到指定目录
    - 参数:
      upload_to = ""   上传文件的保存路径
      storage = None   存储组件,默认django.core.files.storage.FileSystemStorage
      width_field=None,  上传图片的高度保存的数据库字段名(字符串)
      height_field=None  上传图片的宽度保存的数据库字段名(字符串)
 
  DateTimeField(DateField)
    - 日期+时间格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ]
 
  DateField(DateTimeCheckMixin, Field)
    - 日期格式   YYYY-MM-DD
 
  TimeField(DateTimeCheckMixin, Field)
    - 时间格式   HH:MM[:ss[.uuuuuu]]
 
  DurationField(Field)
    - 长整数,时间间隔,数据库中按照bigint存储,ORM中获取的值为datetime.timedelta类型
 
  FloatField(Field)
    - 浮点型
 
  DecimalField(Field)
    - 10进制小数
    - 参数:
      max_digits,小数总长度
      decimal_places,小数位长度
 
  BinaryField(Field)
    - 二进制类型

ORM字段与数据库实际字段的对应关系

对应关系:
  'AutoField': 'integer AUTO_INCREMENT',
  'BigAutoField': 'bigint AUTO_INCREMENT',
  'BinaryField': 'longblob',
  'BooleanField': 'bool',
  'CharField': 'varchar(%(max_length)s)',
  'CommaSeparatedIntegerField': 'varchar(%(max_length)s)',
  'DateField': 'date',
  'DateTimeField': 'datetime',
  'DecimalField': 'numeric(%(max_digits)s, %(decimal_places)s)',
  'DurationField': 'bigint',
  'FileField': 'varchar(%(max_length)s)',
  'FilePathField': 'varchar(%(max_length)s)',
  'FloatField': 'double precision',
  'IntegerField': 'integer',
  'BigIntegerField': 'bigint',
  'IPAddressField': 'char(15)',
  'GenericIPAddressField': 'char(39)',
  'NullBooleanField': 'bool',
  'OneToOneField': 'integer',
  'PositiveIntegerField': 'integer UNSIGNED',
  'PositiveSmallIntegerField': 'smallint UNSIGNED',
  'SlugField': 'varchar(%(max_length)s)',
  'SmallIntegerField': 'smallint',
  'TextField': 'longtext',
  'TimeField': 'time',
  'UUIDField': 'char(32)',

字段参数

null:用于表示某个字段可以为空

unique:如果设置为unique=True 则该字段在此表中必须是唯一的 。

db_index:如果db_index=True 则代表着为此字段设置数据库索引。

default:为该字段设置默认值。

db_column:设置该属性在数据库表中所对应的字段名

DatetimeField、DateField、TimeField这个三个时间字段,都可以设置如下属性。

auto_now_add:配置auto_now_add=True,创建数据记录的时候会把当前时间添加到数据库。

auto_now:配置上auto_now=True,每次更新数据记录的时候会更新该字段。

其它属性详情请查看:官方文档

关系字段

ForeignKey

外键类型在ORM中用来表示外键关联关系,一般把ForeignKey字段设置在 '一对多'中'多'的一方。ForeignKey可以和其他表做关联关系同时也可以和自身做关联关系。

字段参数:

- to:设置要关联的表
- to_field:设置要关联的表的字段
- related_name:反向操作时,使用的字段名,用于代替原反向查询时的'表名_set'。
 
	class Classes(models.Model):
		name = models.CharField(max_length=32)
 
	class Student(models.Model):
		name = models.CharField(max_length=32)
		theclass = models.ForeignKey(to="Classes")
 
	当我们要查询某个班级关联的所有学生(反向查询)时,我们会这么写:
 
	models.Classes.objects.first().student_set.all()
 
	当我们在ForeignKey字段中添加了参数 related_name 后,
 
	class Student(models.Model):
		name = models.CharField(max_length=32)
		theclass = models.ForeignKey(to="Classes", related_name="students")
 
	当我们要查询某个班级关联的所有学生(反向查询)时,我们会这么写:
 
	models.Classes.objects.first().students.all()
 
- related_query_name:反向查询操作时,使用的连接前缀,用于替换表名。
- on_delete:当删除关联表中的数据时,当前表与其关联的行的行为。
	
	models.CASCADE:删除关联数据,与之关联也删除
	models.DO_NOTHING:删除关联数据,引发错误IntegrityError
	models.PROTECT:删除关联数据,引发错误ProtectedError
	models.SET_NULL:删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空)
	models.SET_DEFAULT:删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值)
	models.SET:删除关联数据,
		a. 与之关联的值设置为指定值,设置:models.SET(值)
		b. 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)
		
		def func():
			return 10
 
		class MyModel(models.Model):
			user = models.ForeignKey(
				to="User",
				to_field="id",
				on_delete=models.SET(func)
			)
- db_constraint:是否在数据库中创建外键约束,默认为True。

OneToOneField

一对一字段。通常一对一字段用来扩展已有字段。

示例:

class Author(models.Model):
  name = models.CharField(max_length=32)
  info = models.OneToOneField(to='AuthorInfo')
  
 
class AuthorInfo(models.Model):
  phone = models.CharField(max_length=11)
  email = models.EmailField()

字段参数:

to:设置要关联的表

to_field:设置要关联的字段。

on_delete:同ForeignKey字段。

ManyToManyField

在数据库中通过第三张表来建立关联关系。

字段参数:

to:设置要关联的表

related_name:同ForeignKey字段。

related_query_name:同ForeignKey字段。

symmetrical:仅用于多对多自关联时,指定内部是否创建反向操作的字段。默认为True。

举个例子:

class Person(models.Model):
  name = models.CharField(max_length=16)
  friends = models.ManyToManyField("self")

此时,person对象就没有person_set属性。

class Person(models.Model):
  name = models.CharField(max_length=16)
  friends = models.ManyToManyField("self", symmetrical=False)

此时,person对象现在就可以使用person_set属性进行反向查询。

through:在使用ManyToManyField字段时,Django将自动生成一张表来管理多对多的关联关系。但我们也可以手动创建第三张表来管理多对多关系,此时就需要通过through来指定第三张表的表名。

through_fields:设置关联的字段。

db_table:默认创建第三张表时,数据库中表的名称。

创建多对多关联关系的三种方式

方式一:自行创建第三张表

class Book(models.Model):
  title = models.CharField(max_length=32, verbose_name="书名")
 
 
class Author(models.Model):
  name = models.CharField(max_length=32, verbose_name="作者姓名")
 
 
# 自己创建第三张表,分别通过外键关联书和作者
class Author2Book(models.Model):
  author = models.ForeignKey(to="Author")
  book = models.ForeignKey(to="Book")
 
  class Meta:
    unique_together = ("author", "book")

方式二:通过ManyToManyField自动创建第三张表

class Book(models.Model):
  title = models.CharField(max_length=32, verbose_name="书名")
 
 
# 通过ORM自带的ManyToManyField自动创建第三张表
class Author(models.Model):
  name = models.CharField(max_length=32, verbose_name="作者姓名")
  books = models.ManyToManyField(to="Book", related_name="authors")

方式三:设置ManyTomanyField并指定自行创建的第三张表

class Book(models.Model):
  title = models.CharField(max_length=32, verbose_name="书名")
 
 
# 自己创建第三张表,并通过ManyToManyField指定关联
class Author(models.Model):
  name = models.CharField(max_length=32, verbose_name="作者姓名")
  books = models.ManyToManyField(to="Book", through="Author2Book", through_fields=("author", "book"))
  # through_fields接受一个2元组('field1','field2'):
  # 其中field1是定义ManyToManyField的模型外键的名(author),field2是关联目标模型(book)的外键名。
 
 
class Author2Book(models.Model):
  author = models.ForeignKey(to="Author")
  book = models.ForeignKey(to="Book")
 
  class Meta:
    unique_together = ("author", "book")

注意:当我们需要在第三张关系表中存储额外的字段时,就要使用第三种方式。

元信息

ORM对应的类里面包含另一个Meta类,而Meta类封装了一些数据库的信息。主要字段如下:

db_table: ORM在数据库中的表名默认是 app_类名,可以通过db_table可以重写表名。

index_together: 联合索引

unique_together: 联合唯一索引

ordering: 指定默认按什么字段排序。只有设置了该属性,我们查询到的结果才可以被reverse()。

其他属性详情请查看:官方文档

以上这篇django模型动态修改参数,增加 filter 字段的方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
布同自制Python函数帮助查询小工具
Mar 13 Python
在Python中实现贪婪排名算法的教程
Apr 17 Python
python3编码问题汇总
Sep 06 Python
Python基于list的append和pop方法实现堆栈与队列功能示例
Jul 24 Python
Python+Turtle动态绘制一棵树实例分享
Jan 16 Python
Django 根据数据模型models创建数据表的实例
May 27 Python
opencv python 图像去噪的实现方法
Aug 31 Python
Python安装与基本数据类型教程详解
May 29 Python
python pytest进阶之conftest.py详解
Jun 27 Python
详解python列表(list)的使用技巧及高级操作
Aug 15 Python
python判断all函数输出结果是否为true的方法
Dec 03 Python
python实现剪贴板的操作
Jul 01 Python
Python Django2 model 查询介绍(条件、范围、模糊查询)
Mar 16 #Python
python高阶函数map()和reduce()实例解析
Mar 16 #Python
Django models filter筛选条件详解
Mar 16 #Python
python递归调用中的坑:打印有值, 返回却None
Mar 16 #Python
django 前端页面如何实现显示前N条数据
Mar 16 #Python
Python迭代器Iterable判断方法解析
Mar 16 #Python
python 递归调用返回None的问题及解决方法
Mar 16 #Python
You might like
PHP字符串 ==比较运算符的副作用
2009/10/21 PHP
PHP  实现等比压缩图片尺寸和大小实例代码
2016/10/08 PHP
深入分析PHP设计模式
2020/06/15 PHP
PHP http请求超时问题解决方案
2020/11/13 PHP
禁止F5等快捷键的JS代码
2007/03/06 Javascript
javascript document.execCommand() 常用解析
2009/12/14 Javascript
深入document.write()与HTML4.01的非成对标签的详解
2013/05/08 Javascript
jQuery的控件及事件(输入控件及回车事件)使用示例
2013/07/25 Javascript
nodejs分页类代码分享
2014/06/17 NodeJs
nodejs实现获取当前url地址及url各种参数值
2015/06/25 NodeJs
jQuery实现textarea自动增长宽高的方法
2015/12/18 Javascript
JavaScript中的 attribute 和 jQuery中的 attr 方法浅析
2017/01/04 Javascript
react-native 圆弧拖动进度条实现的示例代码
2018/04/12 Javascript
javaScript强制保留两位小数的输入数校验和小数保留问题
2018/05/09 Javascript
vue服务端渲染缓存应用详解
2018/09/12 Javascript
Vue slot用法(小结)
2018/10/22 Javascript
JavaScript 点击触发复制功能实例详解
2018/11/02 Javascript
ES6基础之默认参数值
2019/02/21 Javascript
Vue实现数据表格合并列rowspan效果
2020/11/30 Javascript
layer的prompt弹出框,点击回车,触发确定事件的方法
2019/09/06 Javascript
如何使用JavaScript检测空闲的浏览器选项卡
2020/05/28 Javascript
[04:40]DOTA2-DPC中国联赛1月26日Recap集锦
2021/03/11 DOTA
django 开发忘记密码通过邮箱找回功能示例
2018/04/17 Python
Python中pillow知识点学习
2018/04/30 Python
对python中dict和json的区别详解
2018/12/18 Python
微信小程序python用户认证的实现
2019/07/29 Python
Python队列RabbitMQ 使用方法实例记录
2019/08/05 Python
Python 忽略文件名编码的方法
2020/08/01 Python
求职简历中个人的自我评价
2013/12/01 职场文书
大专生求职信
2014/06/29 职场文书
2014党员四风对照检查材料思想汇报
2014/09/17 职场文书
计划生育个人总结
2015/03/02 职场文书
2015年社区计生工作总结
2015/04/21 职场文书
从事会计工作年限证明
2015/06/23 职场文书
帮你提高开发效率的JavaScript20个技巧
2021/06/18 Javascript
Centos7 Shell编程之正则表达式、文本处理工具详解
2022/08/05 Servers