代码伺候:
先看如下代码:
例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 以...结尾,忽略大小写
以上这篇浅谈在django中使用filter()(即对QuerySet操作)时踩的坑就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 完美倒立.2024-夜色碳酸【草台回声】【FLAC分轨】
- 杨青《半山听雨贰HQ》头版限量编号[低速原抓WAV+CUE]
- 白玛多吉《云上西藏1+2》DTS-WAV
- 模拟之声慢刻CD《柏林之声3》[正版CD原抓WAV+CUE]
- 威神V(WayV)《The Highest》[FLAC/分轨][259.1MB]
- 余超颖《迷焕纪》[320K/MP3][201.15MB]
- 余超颖《迷焕纪》[FLAC/分轨][784.22MB]
- 温岚.2005-爱回温新歌加精选2CD【阿尔发】【WAV+CUE】
- 尤雅.1990-台语怀念金曲特选辑【太阳神】【WAV+CUE】
- 群星.2024-七夜雪电视剧影视原声带【听见时代】【FLAC分轨】
- 群星《胎教音乐 古典钢琴曲与水晶摇篮曲》[320K/MP3][134.14MB]
- 群星《胎教音乐 古典钢琴曲与水晶摇篮曲》[FLAC/分轨][654.13MB]
- 许惠钧《睡眠钢琴与校园民歌金曲 空灵新世纪催眠曲》[320K/MP3][201.15MB]
- wbg战队国籍分别都是哪里的 wbg战队2024阵容国籍介绍
- wbg战队教练是韩国人吗 s14wbg战队教练国籍介绍