Django惰性機制 html
所謂惰性機制:Publisher.objects.all()或者.filter()等都只是返回了一個QuerySet(查詢結果集對象),它並不會立刻執行sql,而是當調用QuerySet的時候才執行。 sql
惰性機制之可迭代數據庫
# 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緩存問題htm
Django有本身的緩存,若是2次的obj對象一致,第二次的查值直接從緩存中取值。 對象
若是期間數據庫的內容做了更改,則須要從新查值。不然容易產生髒數據。 ip
能夠直接利用第一次的obj對象直接進行update操做,這樣下次for循環查詢時又從新執行了數據庫查詢操做,此時緩存也做了更改; 也能夠從新手動查詢一下結果,可是不推薦這樣,由於咱們並不知道數據何時會進行修改,妥善的仍是Django用數據時本身去查詢數據結果內存
注意1: 若是2次操做之間有數據進行了修改 ,則須要從新從數據庫中查值,不然Django會從緩存中取出數據,影響最後的查詢結果。get
# 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對象,因此從緩存中取值
正確操做: it
1. 從新執行查詢 objs=models.Book.objects.all() 【不推薦】
2. 利用objs.update(title='YYY'); 此時數據庫已經更改,緩存內的值也作了更改
注意2:
if objs(): 查詢數據庫,而且將查詢的全部數據結果放入數據庫內 if objs.exist(): 僅僅查詢數據庫,可是不會把全部的數據放入數據庫內, if obj.iterator():數據放入迭代器內,用一次迭代一次取一次便可