Django的惰性机制是什么?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
为洛龙等地区用户提供了全套网页设计制作服务,及洛龙网站建设行业解决方案。主营业务为网站设计制作、成都做网站、洛龙网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
Django 惰性机制
惰性机制:Publisher.objects.all()或者.filter()等都只是返回了一个QuerySet(查询结果集对象),它并不会马上执行sql,而是当调用QuerySet的时候才执行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 语句没有执行。
调用 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 语句已执行。
看完上述内容,你们掌握Django的惰性机制是什么的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!