浅谈在django中使用filter()(即对QuerySet操作)时踩的坑


Posted in Python onMarch 31, 2020

代码伺候:

先看如下代码:

例1:

  message = Message.objects.filter(pk=message_id2)
 
   message[0].id = message_id2
   message[0].content = content2
   message[0].message_type = message_type2
print(message[0].id)
print(message[0].content)
 
   message[0].save()

可正常从QuerySet中读取数据,并打印出来,无误。可是无法将数据同步到数据库中。

(1)all()返回的是QuerySet对象,程序并没有真的在数据库中执行SQL语句查询数据,但支持迭代,使用for循环可以获取数据。

例如有Book表,其包含bookname,booknum两个属性, 如何使用Objects.all(),得到bookname和booknum的值

(2)filter() 返回的是QuerySet对象,与all()相似,只是all()是查询所有数据,常用:filter表示‘ = ',exclude表示' != '。

(3)get()返回的是Model对象,类型为列表,说明使用get方法会直接执行sql语句获取数据。

来看一个QuerySet对象:

浅谈在django中使用filter()(即对QuerySet操作)时踩的坑

message = Message.objects.filter(pk=message_id2)
message[0].content

这样子确实可以读取到QuerySet中的数据,可是对QuerySet修改后的数据无法保存到数据库。

例1中不要尝试通过message.save()的方式去同步数据到数据库,因为QuerySet不存在save()方法。

正确写法如下:

要想同步到数据库中,需使用对象进行数据同步操作。

例2:

message = Message.objects.filter(pk=message_id2).first()
 
   message.id = message_id2
   message.content = content2
   message.message_type = message_type2
   message.save()

补充知识:Django filter和get的个人体会

开发环境:Ubuntu16.04+Django 1.11.9+Python2.7

filter返回的QuerySet:

filter返回的是QuerySet,可以切片以及遍历,get则不行.因为get只能获取唯一存在的数据,不存在或者存在多条都会报错.

在没有符合条件的值的时候:

get会报错

Book matching query does not exist.

filter则返回一个空列表,并不会报错.

<QuerySet []>`

继续往下执行代码

判断filter是否有值的时候:

book_info = Book.objects.filter(id=book_id, request_type=2)

queryset.exists()
if book_info.exists():

queryset.count==0:
if queryset.count>0:
  pass
else:
  pass
if queryset:
if queryset:
  pass
else:
  pass

filter也会有报错的情况:

filter字段类型为int的时候,输入的参数却是str的时候会报错:

invalid literal for int() with base 10: 'Yu'

使用get的时候,错误信息与上面filter一致.

filter字段存在,但是filter不到对应值的时候:

输出为:<QuerySet []>

为空的时候,自然也不能[0],取值.

使用filter作为过滤条件更新数据的时候:

Book.objects.filter(id=book_id, request_type=2).order_by("-time")[0].update(result=note)

会报错:

'Book' object has no attribute 'update'

使用filter不能部分更新,必须更新所有符合条件的.

但是可以使用[0]可以获取符合过滤条件的第一个值,

解决办法,使用save():

book_info = Book.objects.filter(id=book_id, request_type=2).order_by("-time")[0]
book_info.result = note
book_info.save()

filter 字段后常见的

这里是双下划线,__

__gt 大于
__gte 大于等于
__lt 小于
__lte 小于等于
__contains 包含
__icontains 包含 忽略大小写
__startswith 以...开头
__istartswith 以...开头 忽略大小写
__endswith 以...结尾
__iendswith 以...结尾,忽略大小写

以上这篇浅谈在django中使用filter()(即对QuerySet操作)时踩的坑就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
在Python中操作时间之tzset()方法的使用教程
May 22 Python
Python实现比较扑克牌大小程序代码示例
Dec 06 Python
Python程序退出方式小结
Dec 09 Python
Python+selenium实现截图图片并保存截取的图片
Jan 05 Python
pip matplotlib报错equired packages can not be built解决
Jan 06 Python
Python pyinotify日志监控系统处理日志的方法
Mar 08 Python
Django基于ORM操作数据库的方法详解
Mar 27 Python
python绘制热力图heatmap
Mar 23 Python
解决pandas .to_excel不覆盖已有sheet的问题
Dec 10 Python
Django获取应用下的所有models的例子
Aug 30 Python
关于Python字符串显示u...的解决方式
Mar 06 Python
Pytorch转tflite方式
May 25 Python
Python sorted排序方法如何实现
Mar 31 #Python
解决Django中checkbox复选框的传值问题
Mar 31 #Python
Python文本文件的合并操作方法代码实例
Mar 31 #Python
Python调用接口合并Excel表代码实例
Mar 31 #Python
Python如何批量获取文件夹的大小并保存
Mar 31 #Python
Django使用list对单个或者多个字段求values值实例
Mar 31 #Python
django实现模板中的字符串文字和自动转义
Mar 31 #Python
You might like
ThinkPHP的URL重写问题
2014/06/22 PHP
php查找字符串出现次数的方法
2014/12/01 PHP
jquery 锁定弹出层实现代码
2010/02/23 Javascript
javascript URL编码和解码使用说明
2010/04/12 Javascript
使用jquery读取html5 localstorage的值的方法
2013/01/04 Javascript
javascript将异步校验表单改写为同步表单
2015/01/27 Javascript
谈谈因Vue.js引发关于getter和setter的思考
2016/12/02 Javascript
Vue.js实战之Vuex的入门教程
2017/04/01 Javascript
详解用函数式编程对JavaScript进行断舍离
2017/09/18 Javascript
Vue.directive()的用法和实例详解
2018/03/04 Javascript
微信小程序如何使用globalData的方法
2019/06/06 Javascript
微信小程序 可搜索的地址选择实现详解
2019/08/28 Javascript
基于JS实现简单滑块拼图游戏
2019/10/12 Javascript
vue把输入框的内容添加到页面的实例讲解
2019/11/11 Javascript
Vue.js获取手机系统型号、版本、浏览器类型的示例代码
2020/05/10 Javascript
[03:24]2014DOTA2国际邀请赛 神秘商店生意火爆
2014/07/18 DOTA
深入浅析Python字符编码
2015/11/12 Python
python编写简单爬虫资料汇总
2016/03/22 Python
python数据抓取分析的示例代码(python + mongodb)
2017/12/25 Python
完美解决Pycharm无法导入包的问题 Unresolved reference
2018/05/18 Python
python爬虫解决验证码的思路及示例
2019/08/01 Python
Python实现语音识别和语音合成功能
2019/09/20 Python
Django实现任意文件上传(最简单的方法)
2020/06/03 Python
Python闭包装饰器使用方法汇总
2020/06/29 Python
使用ITK-SNAP进行抠图操作并保存mask的实例
2020/07/01 Python
纯css3实现图片翻牌特效
2015/03/10 HTML / CSS
东南亚冒险旅行与活动:Adventoro
2019/10/16 全球购物
阿联酋手表和配饰购物网站:Rivolishop
2019/11/25 全球购物
大学生毕业自我鉴定
2013/11/06 职场文书
群众路线自我剖析材料
2014/10/08 职场文书
2014年人事工作总结范文
2014/11/19 职场文书
贷款工资证明范本
2015/06/12 职场文书
张丽莉观后感
2015/06/16 职场文书
关于环保的宣传稿
2015/07/23 职场文书
2016年记者节感言
2015/12/08 职场文书
Fluentd搭建日志收集服务
2022/09/23 Servers