您好,登錄后才能下訂單哦!
Django的惰性機制是什么?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
Django 惰性機制
惰性機制:Publisher.objects.all()或者.filter()等都只是返回了一個QuerySet(查詢結果集對象),它并不會馬上執(zhí)行sql,而是當調用QuerySet的時候才執(zhí)行sql,為了測試,我們加上 sql 日志。
在 settings.py 文件上修改
# 在最后添加 LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'handlers': { 'console':{ 'level':'DEBUG', 'class':'logging.StreamHandler', }, }, 'loggers': { 'django.db.backends': { 'handlers': ['console'], 'propagate': True, 'level':'DEBUG', }, } }
在 views.py 上修改
from django.shortcuts import render, HttpResponse from app01 import models from app01.models import Book,Author,Publisher # Create your views here. def data_oper(req): obj_set = models.Book.objects.filter(id=2) return HttpResponse("Hello world")
瀏覽器訪問 http://127.0.0.1:8000/data_oper/ 結果顯示 sql 語句沒有執(zhí)行。
調用 QuerySet ,在 views.py 上修改
rom django.shortcuts import render, HttpResponse from app01 import models from app01.models import Book,Author,Publisher # Create your views here. def data_oper(req): obj_set = models.Book.objects.filter(id=2) for obj in obj_set: print(obj.title) return HttpResponse("Hello world")
瀏覽器訪問 http://127.0.0.1:8000/data_oper/ 結果顯示 sql 語句已執(zhí)行。
看完上述內容,你們掌握Django的惰性機制是什么的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。