浅谈在django中使用filter()(即对QuerySet操作)时踩的坑
作者:小耗lhx 发布时间:2022-05-03 10:24:49
代码伺候:
先看如下代码:
例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对象:
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 以...结尾,忽略大小写
来源:https://www.cnblogs.com/xiaohaodeboke/p/12583783.html
猜你喜欢
- 前言生成器generator生成器的本质是一个迭代器(iterator)要理解生成器,就要在理解一下迭代,可迭代对象,迭代器,这三个概念Py
- 一直以来,我们大多使用js来实现弹出菜单,可是根据 w3c 的css标准,根本就没有这个必要。只需要简单得使用css+html就可以做出一个
- 在我发表上一篇《Zen Coding: 一种快速编写HTML/CSS代码的方法》之后,有网友表示不知道怎么在Dreamweaver上使用ze
- 本文实例讲述了Python多进程机制。分享给大家供大家参考。具体如下:在以前只是接触过PYTHON的多线程机制,今天搜了一下多进程,相关文章
- 把你想加密的文档的源代码拷贝到下面的文本框内,按下生成按钮就可以得到一段加密了的页面代码,把代码复制到新的页面就可以了. [注意:可重复加密
- 返回首页的链接地址,有三种方法:1、一般方法是,直接写对应的域名地址,<a href="http://www.zfnn.co
- 本文实例为大家分享了python策略模式代码,供大家参考,具体内容如下"""策略模式""&
- 本文中介绍了一个MySQL的存储过程,其中涉及Cursor的使用,示例如下:CREATE PROCEDURE `justifyGroupNu
- 什么是 Python 中的 Lambda 函数今天我们来学习 Python 中的 lambda 函数,并探讨使用它的优点和局限性Let
- 目录一、pyecharts绘制饼图语法简介二、绘制普通饼图三、绘制圆环图四、绘制饼图-玫瑰图一、pyecharts绘制饼图语法简介饼图主要用
- 本文实例讲述了python排序方法。分享给大家供大家参考。具体如下:>>> def my_key1(x):... &nbs
- 对于路径中含有中文的图像,直接用cv2.imread读取会报错,上次看到有大佬使用cv2.imdecode就可以正常读取,有点好奇,所以今天
- 初级的图像拼接为将两幅图像简单的粘贴在一起,仅仅是图像几何空间的转移与合成,与图像内容无关。高级图像拼接也叫作基于特征匹配的图像拼接,拼接时
- 困扰我很久问题终于在昨天被解决了。其实问题很简单<% =now %>老是显示12小时制,总是出现上午、下午。这个问题虽然很小,但
- 目前python 提供了几种多线程实现方式 thread,threading,multithreading ,其中thread模块比较底层,
- 从 PDF 表格中获取数据是一项痛苦的工作。不久前,一位开发者提供了一个名为 Camelot 的工具,使用三行代码就能从 PDF 文件中提取
- 有一些数据我们是没法直观的查看的,需要通过抓取去获得。听到指数这个词,有的小伙伴们觉得很复杂,似乎只在股票的时候才听说的,比如一些数据的涨跌
- 1、前不久,friendfeed.com把主导航从上面,移到了右侧。现在,又改到了左侧。2、现在,twitter.com把页签(相当于二级导
- 代码如下: <!--[if IE 6]><script type="text/javascript"&
- 学习目的: 掌握最基本的Label、TextBox、Button控件用法 掌握用StringBuider类连接字符串 理解服务器的环境变量