日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

python 惰性_Python学习---django惰性机制

發布時間:2025/4/16 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python 惰性_Python学习---django惰性机制 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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 惰性_Python学习---django惰性机制的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。