电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

淺談在django中使用filter()(即對(duì)QuerySet操作)時(shí)踩的坑

瀏覽:7日期:2024-10-14 14:09:49

代碼伺候:

先看如下代碼:

例1:

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

可正常從QuerySet中讀取數(shù)據(jù),并打印出來(lái),無(wú)誤。可是無(wú)法將數(shù)據(jù)同步到數(shù)據(jù)庫(kù)中。

(1)all()返回的是QuerySet對(duì)象,程序并沒(méi)有真的在數(shù)據(jù)庫(kù)中執(zhí)行SQL語(yǔ)句查詢(xún)數(shù)據(jù),但支持迭代,使用for循環(huán)可以獲取數(shù)據(jù)。

例如有Book表,其包含bookname,booknum兩個(gè)屬性, 如何使用Objects.all(),得到bookname和booknum的值

(2)filter() 返回的是QuerySet對(duì)象,與all()相似,只是all()是查詢(xún)所有數(shù)據(jù),常用:filter表示‘ = ’,exclude表示’ != ’。

(3)get()返回的是Model對(duì)象,類(lèi)型為列表,說(shuō)明使用get方法會(huì)直接執(zhí)行sql語(yǔ)句獲取數(shù)據(jù)。

來(lái)看一個(gè)QuerySet對(duì)象:

淺談在django中使用filter()(即對(duì)QuerySet操作)時(shí)踩的坑

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

這樣子確實(shí)可以讀取到QuerySet中的數(shù)據(jù),可是對(duì)QuerySet修改后的數(shù)據(jù)無(wú)法保存到數(shù)據(jù)庫(kù)。

例1中不要嘗試通過(guò)message.save()的方式去同步數(shù)據(jù)到數(shù)據(jù)庫(kù),因?yàn)镼uerySet不存在save()方法。

正確寫(xiě)法如下:

要想同步到數(shù)據(jù)庫(kù)中,需使用對(duì)象進(jìn)行數(shù)據(jù)同步操作。

例2:

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

補(bǔ)充知識(shí):Django filter和get的個(gè)人體會(huì)

開(kāi)發(fā)環(huán)境:Ubuntu16.04+Django 1.11.9+Python2.7

filter返回的QuerySet:

filter返回的是QuerySet,可以切片以及遍歷,get則不行.因?yàn)間et只能獲取唯一存在的數(shù)據(jù),不存在或者存在多條都會(huì)報(bào)錯(cuò).

在沒(méi)有符合條件的值的時(shí)候:

get會(huì)報(bào)錯(cuò)

Book matching query does not exist.

filter則返回一個(gè)空列表,并不會(huì)報(bào)錯(cuò).

<QuerySet []>`

繼續(xù)往下執(zhí)行代碼

判斷filter是否有值的時(shí)候:

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

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

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

if queryset:if queryset: passelse: pass

filter也會(huì)有報(bào)錯(cuò)的情況:

filter字段類(lèi)型為int的時(shí)候,輸入的參數(shù)卻是str的時(shí)候會(huì)報(bào)錯(cuò):

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

使用get的時(shí)候,錯(cuò)誤信息與上面filter一致.

filter字段存在,但是filter不到對(duì)應(yīng)值的時(shí)候:

輸出為:<QuerySet []>

為空的時(shí)候,自然也不能[0],取值.

使用filter作為過(guò)濾條件更新數(shù)據(jù)的時(shí)候:

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

會(huì)報(bào)錯(cuò):

’Book’ object has no attribute ’update’

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

但是可以使用[0]可以獲取符合過(guò)濾條件的第一個(gè)值,

解決辦法,使用save():

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

filter 字段后常見(jiàn)的

這里是雙下劃線(xiàn),__

__gt 大于__gte 大于等于__lt 小于__lte 小于等于__contains 包含 __icontains 包含 忽略大小寫(xiě) __startswith 以...開(kāi)頭__istartswith 以...開(kāi)頭 忽略大小寫(xiě)__endswith 以...結(jié)尾__iendswith 以...結(jié)尾,忽略大小寫(xiě)

以上這篇淺談在django中使用filter()(即對(duì)QuerySet操作)時(shí)踩的坑就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 河南中整光饰机械有限公司-抛光机,去毛刺抛光机,精密镜面抛光机,全自动抛光机械设备 | cnc精密加工_数控机械加工_非标平键定制生产厂家_扬州沃佳机械有限公司 | 传动滚筒_厂家-淄博海恒机械制造厂 | 不锈钢/气体/液体玻璃转子流量计(防腐,选型,规格)-常州天晟热工仪表有限公司【官网】 | 蚂蚁分类信息系统 - PHP同城分类信息系统 - MayiCMS | 北京包装设计_标志设计公司_包装设计公司-北京思逸品牌设计 | KBX-220倾斜开关|KBW-220P/L跑偏开关|拉绳开关|DHJY-I隔爆打滑开关|溜槽堵塞开关|欠速开关|声光报警器-山东卓信有限公司 | 细胞染色-流式双标-试剂盒免费代做-上海研谨生物科技有限公司 | 自动钻孔机-全自动数控钻孔机生产厂家-多米(广东)智能装备有限公司 | 消防泵-XBD单级卧式/立式消防泵-上海塑泉泵阀(集团)有限公司 | 焊接烟尘净化器__焊烟除尘设备_打磨工作台_喷漆废气治理设备 -催化燃烧设备 _天津路博蓝天环保科技有限公司 | 电气控制系统集成商-PLC控制柜变频控制柜-非标自动化定制-电气控制柜成套-NIDEC CT变频器-威肯自动化控制 | 企业VI设计_LOGO设计公司_品牌商标设计_【北京美研】 | 网站制作优化_网站SEO推广解决方案-无锡首宸信息科技公司 | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-北京罗伦过滤技术集团有限公司 | 耐热钢-耐磨钢-山东聚金合金钢铸造有限公司 | 防爆型气象站_农业气象站_校园气象站_农业四情监测系统「山东万象环境科技有限公司」 | 手板_手板模型制作_cnc手板加工厂-东莞天泓 | 样品瓶(色谱样品瓶)百科-浙江哈迈科技有限公司 | 中式装修设计_室内中式装修_【云臻轩】中式设计机构 | CXB船用变压器-JCZ系列制动器-HH101船用铜质开关-上海永上船舶电器厂 | 郑州水质检测中心_井水检测_河南废气检测_河南中环嘉创检测 | 无锡网站建设-做网站-建网站-网页设计制作-阿凡达建站公司 | WF2户外三防照明配电箱-BXD8050防爆防腐配电箱-浙江沃川防爆电气有限公司 | 硫酸钡厂家_高光沉淀硫酸钡价格-河南钡丰化工有限公司 | 焊管生产线_焊管机组_轧辊模具_焊管设备_焊管设备厂家_石家庄翔昱机械 | 深圳希玛林顺潮眼科医院(官网)│深圳眼科医院│医保定点│香港希玛林顺潮眼科中心连锁品牌 | 沈阳楼承板_彩钢板_压型钢板厂家-辽宁中盛绿建钢品股份有限公司 轴承振动测量仪电箱-轴承测振动仪器-测试仪厂家-杭州居易电气 | 新密高铝耐火砖,轻质保温砖价格,浇注料厂家直销-郑州荣盛窑炉耐火材料有限公司 | 杜甫仪器官网|实验室平行反应器|升降水浴锅|台式低温循环泵 | 粘度计维修,在线粘度计,二手博勒飞粘度计维修|收购-天津市祥睿科技有限公司 | 烘箱-工业烘箱-工业电炉-实验室干燥箱 - 苏州华洁烘箱制造有限公司 | 馋嘴餐饮网_餐饮加盟店火爆好项目_餐饮连锁品牌加盟指南创业平台 | 电加热导热油炉-空气加热器-导热油加热器-翅片电加热管-科安达机械 | 合肥汽车充电桩_安徽充电桩_电动交流充电桩厂家_安徽科帝新能源科技有限公司 | 龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司_龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司 | 胀套-锁紧盘-风电锁紧盘-蛇形联轴器「厂家」-瑞安市宝德隆机械配件有限公司 | 离子色谱自动进样器-青岛艾力析实验科技有限公司 | 防水套管-柔性防水套管-刚性防水套管-上海执品管件有限公司 | 喷漆房_废气处理设备-湖北天地鑫环保设备有限公司 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 |