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', }, } }
相关推荐:《Python视频教程》
在 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 语句已执行。
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 模板不会安装或需要功能定制以及二次开发?
发表评论
还没有评论,快来抢沙发吧!