亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2020年03月31日 14:40:03   作者:小耗lhx  
這篇文章主要介紹了淺談在django中使用filter()(即對(duì)QuerySet操作)時(shí)踩的坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

代碼伺候:

先看如下代碼:

例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中讀取數(shù)據(jù),并打印出來(lái),無(wú)誤??墒菬o(wú)法將數(shù)據(jù)同步到數(shù)據(jù)庫(kù)中。

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

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

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

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

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

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:
  pass
else:
  pass
if queryset:
if queryset:
  pass
else:
  pass

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

filter字段類型為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 = note
book_info.save()

filter 字段后常見(jià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è)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用Python和scikit-learn創(chuàng)建混淆矩陣的示例詳解

    使用Python和scikit-learn創(chuàng)建混淆矩陣的示例詳解

    這篇文章主要介紹了使用Python和scikit-learn創(chuàng)建混淆矩陣的示例詳解,該示例包括生成數(shù)據(jù)集、為數(shù)據(jù)集選擇合適的機(jī)器學(xué)習(xí)模型、構(gòu)建、配置和訓(xùn)練它,最后解釋結(jié)果,即混淆矩陣,需要的朋友可以參考下
    2022-06-06
  • Python?__all__變量用法示例詳解

    Python?__all__變量用法示例詳解

    這篇文章主要介紹了Python?__all__變量用法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • Python Web程序搭建簡(jiǎn)單的Web服務(wù)器

    Python Web程序搭建簡(jiǎn)單的Web服務(wù)器

    這篇文章主要介紹了Python Web程序搭建簡(jiǎn)單的Web服務(wù)器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • PyQt QCombobox設(shè)置行高的方法

    PyQt QCombobox設(shè)置行高的方法

    今天小編就為大家分享一篇PyQt QCombobox設(shè)置行高的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-06-06
  • 基于nexus3配置Python倉(cāng)庫(kù)過(guò)程詳解

    基于nexus3配置Python倉(cāng)庫(kù)過(guò)程詳解

    這篇文章主要介紹了基于nexus3配置Python倉(cāng)庫(kù)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • Python 中的單分派泛函數(shù)你真的了解嗎

    Python 中的單分派泛函數(shù)你真的了解嗎

    singledispatch是標(biāo)準(zhǔn)庫(kù)functools模塊的函數(shù) 可以把整體方案拆成多個(gè)模塊,甚至可以為你無(wú)法修改的類提供專門(mén)的函數(shù),使用@singledispatch裝飾的函數(shù)會(huì)變成泛函數(shù),本文帶領(lǐng)大家再次學(xué)習(xí)Python 中的單分派泛函數(shù),一起學(xué)習(xí)下吧
    2021-06-06
  • django框架auth模塊用法實(shí)例詳解

    django框架auth模塊用法實(shí)例詳解

    這篇文章主要介紹了django框架auth模塊用法,結(jié)合實(shí)例形式詳細(xì)分析了Django框架auth模塊登錄驗(yàn)證、注銷等基本操作技巧與使用注意事項(xiàng),需要的朋友可以參考下
    2019-12-12
  • pytorch 調(diào)整某一維度數(shù)據(jù)順序的方法

    pytorch 調(diào)整某一維度數(shù)據(jù)順序的方法

    今天小編就為大家分享一篇pytorch 調(diào)整某一維度數(shù)據(jù)順序的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • el-table 多表格彈窗嵌套數(shù)據(jù)顯示異常錯(cuò)亂問(wèn)題解決方案

    el-table 多表格彈窗嵌套數(shù)據(jù)顯示異常錯(cuò)亂問(wèn)題解決方案

    使用vue+element開(kāi)發(fā)報(bào)表功能時(shí),需要列表上某列的超鏈接按鈕彈窗展示,在彈窗的el-table列表某列中再次使用超鏈接按鈕點(diǎn)開(kāi)彈窗,以此類推多表格彈窗嵌套,本文以彈窗兩次為例,需要的朋友可以參考下
    2023-11-11
  • python 實(shí)現(xiàn)一次性在文件中寫(xiě)入多行的方法

    python 實(shí)現(xiàn)一次性在文件中寫(xiě)入多行的方法

    今天小編就為大家分享一篇python 實(shí)現(xiàn)一次性在文件中寫(xiě)入多行的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01

最新評(píng)論