浅谈在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中使用socket发送HTTP请求数据接收不完整问题解决方法
Feb 04 Python
Django中的CACHE_BACKEND参数和站点级Cache设置
Jul 23 Python
python实现树形打印目录结构
Mar 29 Python
对python使用http、https代理的实例讲解
May 07 Python
Python之list对应元素求和的方法
Jun 28 Python
Python实现多进程的四种方式
Feb 22 Python
Python代码实现删除一个list里面重复元素的方法
Apr 02 Python
python+logging+yaml实现日志分割
Jul 22 Python
pytorch实现focal loss的两种方式小结
Jan 02 Python
记一次django内存异常排查及解决方法
Aug 07 Python
Python如何批量生成和调用变量
Nov 21 Python
jupyter notebook远程访问不了的问题解决方法
Jan 11 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
PHP中的替代语法简介
2014/08/22 PHP
CI框架实现优化文件上传及多文件上传的方法
2017/01/04 PHP
利用PHPExcel读取Excel的数据和导出数据到Excel
2017/05/12 PHP
JavaScript的单例模式 (singleton in Javascript)
2010/06/11 Javascript
javascript中日期转换成时间戳的小例子
2013/03/21 Javascript
Extjs Label的 fieldLabel和html属性值对齐的方法
2014/06/15 Javascript
分步解析JavaScript实现tab选项卡自动切换功能
2016/01/25 Javascript
JQuery遍历元素的父辈和祖先的方法
2016/09/18 Javascript
Node.js创建Web、TCP服务器
2017/12/05 Javascript
详解vue 组件
2020/06/11 Javascript
js实现限定区域范围拖拉拽效果
2020/11/20 Javascript
JS hasOwnProperty()方法检测一个属性是否是对象的自有属性的方法
2021/01/29 Javascript
wxPython中文教程入门实例
2014/06/09 Python
python函数式编程学习之yield表达式形式详解
2018/03/25 Python
python多进程读图提取特征存npy
2019/05/21 Python
Python实现个人微信号自动监控告警的示例
2019/07/03 Python
基于python plotly交互式图表大全
2019/12/07 Python
解决pytorch-yolov3 train 报错的问题
2020/02/18 Python
Python进程的通信Queue、Pipe实例分析
2020/03/30 Python
Python requests.post方法中data与json参数区别详解
2020/04/30 Python
详解python 内存优化
2020/08/17 Python
python文件路径操作方法总结
2020/12/21 Python
使用Python快速打开一个百万行级别的超大Excel文件的方法
2021/03/02 Python
购买英国原创艺术:Art Gallery
2018/08/25 全球购物
诗普兰迪官方网站:Splendid
2018/09/18 全球购物
世界上最好的旅行夹克:BauBax
2018/12/23 全球购物
学生个人的自我评价分享
2013/11/05 职场文书
董事长秘书职责
2014/01/31 职场文书
课前三分钟演讲稿
2014/04/24 职场文书
乡镇领导班子四风整顿行动工作汇报
2014/10/25 职场文书
教师群众路线教育实践活动个人对照检查材料
2014/11/04 职场文书
优秀团员事迹材料
2014/12/25 职场文书
500字作文之关于爸爸
2019/11/14 职场文书
jquery插件实现搜索历史
2021/04/24 jQuery
利用Python将list列表写入文件并读取的方法汇总
2022/03/25 Python
错误码NET::ERR_CERT_DATE_INVALID证书已过期解决方法?
2022/07/07 数码科技