python 惰性_Python学习---django惰性机制
Django惰性機制
所謂惰性機制:Publisher.objects.all()或者.filter()等都只是返回了一個QuerySet(查詢結(jié)果集對象),它并不會馬上執(zhí)行sql,而是當調(diào)用QuerySet的時候才執(zhí)行。
惰性機制之可迭代
# objs=models.Book.objects.all() # [obj1,obj2,ob3...]
# for obj in objs: # 每一obj就是一個行對象,此時會執(zhí)行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對象一致,第二次的查值直接從緩存中取值。
如果期間數(shù)據(jù)庫的內(nèi)容作了更改,則需要重新查值。否則容易產(chǎn)生臟數(shù)據(jù)。
可以直接利用第一次的obj對象直接進行update操作,這樣下次for循環(huán)查詢時又重新執(zhí)行了數(shù)據(jù)庫查詢操作,此時緩存也作了更改; 也可以重新手動查詢一下結(jié)果,但是不推薦這樣,因為我們并不知道數(shù)據(jù)什么時候會進行修改,妥善的還是Django用數(shù)據(jù)時自己去查詢數(shù)據(jù)結(jié)果
注意1: 如果2次操作之間有數(shù)據(jù)進行了修改 ,則需要重新從數(shù)據(jù)庫中查值,否則Django會從緩存中取出數(shù)據(jù),影響最后的查詢結(jié)果。
# objs=models.Book.objects.all() # [obj1,obj2,ob3...]
# for obj in objs: # 每一obj就是一個行對象,此時會執(zhí)行sql
# print("obj:",obj)
Models.Bool.update.get(id=2).update('title'='YYY') # 數(shù)據(jù)庫內(nèi)更改,緩存未更改
# objs=models.Book.objects.all() 重新從數(shù)據(jù)庫內(nèi)查找并賦值給objs
# objs.update(title='YYY') 推薦使用,直接數(shù)據(jù)庫/內(nèi)存都更改了,下面for循環(huán)查詢時重新執(zhí)行了數(shù)據(jù)庫
# objs=models.Book.objects.all() # [obj1,obj2,ob3...]
# for obj in objs:
# print("obj:",obj) # 還是objs對象,所以從緩存中取值
正確操作:
1. 重新執(zhí)行查詢 objs=models.Book.objects.all() 【不推薦】
2. 利用objs.update(title='YYY');? 此時數(shù)據(jù)庫已經(jīng)更改,緩存內(nèi)的值也做了更改
注意2:
if objs(): 查詢數(shù)據(jù)庫,并且將查詢的所有數(shù)據(jù)結(jié)果放入數(shù)據(jù)庫內(nèi)
if objs.exist(): 僅僅查詢數(shù)據(jù)庫,但是不會把所有的數(shù)據(jù)放入數(shù)據(jù)庫內(nèi),
if obj.iterator():數(shù)據(jù)放入迭代器內(nèi),用一次迭代一次取一次即可
總結(jié)
以上是生活随笔為你收集整理的python 惰性_Python学习---django惰性机制的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: postgre 查询注释_postgre
- 下一篇: java 调试 gdb_android