標籤:obj first 結果 迴圈 iterator lte python學習 pytho objects
Django惰性機制
所謂惰性機制:Publisher.objects.all()或者.filter()等都只是返回了一個QuerySet(查詢結果集對象),它並不會馬上執行sql,而是當調用QuerySet的時候才執行。
惰性機制之可迭代
# objs=models.Book.objects.all() # [obj1,obj2,ob3...]# for obj in objs: # 每一obj就是一個行對象,此時會執行sql# print("obj:",obj)
惰性機制之可切片
# objs=models.Book.objects.all() # [obj1,obj2,ob3...]# print(objs[1])# print(objs[1:4])# print(objs[::-1])
惰性機制之Django緩衝問題
Django有自己的緩衝,如果2次的obj對象一致,第二次的查值直接從緩衝中取值。
如果期間資料庫的內容作了更改,則需要重新查值。否則容易產生髒資料。
可以直接利用第一次的obj對象直接進行update操作,這樣下次for迴圈查詢時又重新執行了資料庫查詢操作,此時緩衝也作了更改; 也可以重新手動查詢一下結果,但是不推薦這樣,因為我們並不知道資料什麼時候會進行修改,妥善的還是Django用資料時自己去查詢資料結果
注意1: 如果2次操作之間有資料進行了修改 ,則需要重新從資料庫中查值,否則Django會從緩衝中取出資料,影響最後的查詢結果。
# objs=models.Book.objects.all() # [obj1,obj2,ob3...] # for obj in objs: # 每一obj就是一個行對象,此時會執行sql # print("obj:",obj) Models.Bool.update.get(id=2).update(‘title‘=‘YYY‘) # 資料庫內更改,緩衝未更改# objs=models.Book.objects.all() 重新從資料庫內尋找並賦值給objs# objs.update(title=‘YYY‘) 推薦使用,直接資料庫/記憶體都更改了,下面for迴圈查詢時重新執行了資料庫 # objs=models.Book.objects.all() # [obj1,obj2,ob3...] # for obj in objs: # print("obj:",obj) # 還是objs對象,所以從緩衝中取值
正確操作:
1. 重新執行查詢 objs=models.Book.objects.all() 【不推薦】
2. 利用objs.update(title=‘YYY‘); 此時資料庫已經更改,緩衝內的值也做了更改
注意2:
if objs(): 查詢資料庫,並且將查詢的所有資料結果放入資料庫內if objs.exist(): 僅僅查詢資料庫,但是不會把所有的資料放入資料庫內,if obj.iterator():資料放入迭代器內,用一次迭代一次取一次即可
Python學習---django惰性機制