Django ORM filter() 的运用详解


Posted in Python onMay 14, 2020

最近发布代码的时候,遇到一个问题,发现Python中eval()函数的危险性.然而我还是个菜鸟,其中有一段代码是这样的。

queryset = eval("models.TUserInfo.objects.filter({0})[{1}:{2}]".format(select,page_num * page - page_num,page_num * page))

代码场景:

这是一个获取信息的API.所以需要去数据库里取对应信息,但是你不知道获取信息是根据哪几个字段而来,需要靠用户传入,在这里eval()函数就提供给某些人员很好的入侵性.所以用了另外一种方式去改良代码.

filter(**kwargs): 它包含了与所给筛选条件相匹配的对象

条件查询

条件可以是:参数,字典,Q

def filter(self, *args, **kwargs):
    """
    Returns a new QuerySet instance with the args ANDed to the existing
    set.
    """
    return self._filter_or_exclude(False, *args, **kwargs)

于是乎,便改用了字典传值的方式.避免了先将代码字符串化,然后在将其代码化。

用**dict调用,dict必须是一个字典。

queryset = models.TUserInfo.objects.filter(**field_dict)[page_num * page - page_num:page_num * page]

因为没有想到用其它方式来运用orm,所以有些新奇,用字典传值也不失为一种良好运用。

补充知识:django orm查询中filter与get的区别

输入参数:

get的参数只能是model中定义的哪些字段,只支持严格匹配

filter的参数可以是字段也可以是扩展的where查询关键字,如in,like

返回值:

get返回值是一个定义的model对象

filter返回值是一个新的QuerySet对象,然后可以对QuerySet在进行查询返回新的QuerySet对象,支持链式操作,QuerySet一个集合对象,可使用迭代或者遍历,切片等,但是不等于list类型(是一个object对象集合)

异常:

get只有一条记录返回的时候才正常,也就是说明get查询字段必须是主键或者唯一约束的字段。当返回多条记录或者没有找到记录的时候都会抛出异常

get方法是从数据库的取得一个匹配的结果,返回一个对象,如果记录不存在的话,它会报错,有多条记录也会报错。

filter有没有匹配的记录都可以

filter方法是从数据库的取得匹配的结果,返回一个对象列表,如果记录不存在的话,它会返回[]。

另外,从别的资料里看到filter好像有缓存数据的功能,第一次查询数据库并生成缓存,下次再调用filter方法的话,直接取得缓存的数据,会get方法每次执行都是直接查询数据库的,不知道这个是不是正确,看看就好。

以上这篇Django ORM filter() 的运用详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现多线程下载文件的代码实例
Jun 01 Python
python通过imaplib模块读取gmail里邮件的方法
May 08 Python
Python中使用Queue和Condition进行线程同步的方法
Jan 19 Python
Win7下搭建python开发环境图文教程(安装Python、pip、解释器)
May 17 Python
解决Python网页爬虫之中文乱码问题
May 11 Python
python查看列的唯一值方法
Jul 17 Python
Python版名片管理系统
Nov 30 Python
PyCharm+Qt Designer+PyUIC安装配置教程详解
Jun 13 Python
Python实现的远程文件自动打包并下载功能示例
Jul 12 Python
django的csrf实现过程详解
Jul 26 Python
Django模板标签{% for %}循环,获取制定条数据实例
May 14 Python
python中用ggplot绘制画图实例讲解
Jan 26 Python
Django设置Postgresql的操作
May 14 #Python
numpy矩阵数值太多不能全部显示的解决
May 14 #Python
使用python采集Excel表中某一格数据
May 14 #Python
django 模版关闭转义方式
May 14 #Python
Django表单提交后实现获取相同name的不同value值
May 14 #Python
django模板获取list中指定索引的值方式
May 14 #Python
Django admin管理工具TabularInline类用法详解
May 14 #Python
You might like
php实现的遍历文件夹下所有文件,编辑删除
2010/01/05 PHP
WordPress开发中短代码的实现及相关函数使用技巧
2016/01/05 PHP
PHP图片添加水印功能示例小结
2016/10/03 PHP
Open and Print a Word Document
2007/06/15 Javascript
JSQL  一个 web DB 的封装
2010/05/05 Javascript
解析window.open的使用方法总结
2013/06/19 Javascript
jquery ajax post提交数据乱码
2013/11/05 Javascript
JavaScript实现常用二级省市级联下拉列表的方法
2015/03/25 Javascript
jQuery结合ajax实现动态加载文本内容
2015/05/19 Javascript
JS实现网页右侧带动画效果的伸缩窗口代码
2015/10/29 Javascript
Angular路由简单学习
2016/12/26 Javascript
详解Angularjs 如何自定义Img的ng-load 事件
2017/02/15 Javascript
Element-UI Table组件上添加列拖拽效果实现方法
2018/04/14 Javascript
JS装饰器函数用法总结
2018/04/21 Javascript
MVVM框架下实现分页功能示例
2018/06/14 Javascript
Vue高版本中一些新特性的使用详解
2018/09/25 Javascript
详解vscode中vue代码颜色插件
2018/10/11 Javascript
[05:15]2018年度CS GO社区贡献奖-完美盛典
2018/12/16 DOTA
在Python程序中进行文件读取和写入操作的教程
2015/04/28 Python
python控制台中实现进度条功能
2015/11/10 Python
python3实现ftp服务功能(服务端 For Linux)
2017/03/24 Python
Python3.4学习笔记之类型判断,异常处理,终止程序操作小结
2019/03/01 Python
Python3.5内置模块之random模块用法实例分析
2019/04/26 Python
Python PyInstaller库基本使用方法分析
2019/12/12 Python
FILA德国官方网站:来自意大利的体育和街头服饰品牌
2019/07/19 全球购物
运动会入场词200字
2014/02/15 职场文书
老师的检讨书
2014/02/23 职场文书
促销活动总结怎么写
2014/06/25 职场文书
优秀大专毕业生求职信
2014/08/04 职场文书
2014入党积极分子破除“四风”思想汇报
2014/09/14 职场文书
党员对照检查材料整改措施思想汇报
2014/09/26 职场文书
房屋所有权证明
2014/10/20 职场文书
离婚协议书的范本
2015/01/27 职场文书
企业承诺书格式范文
2015/04/28 职场文书
普希金诗歌赏析(6首)
2019/08/22 职场文书
nginx 配置指令之location使用详解
2022/05/25 Servers