首页 > 其他 > 详细

Django中的惰性机制

时间:2019-11-06 16:23:24      阅读:90      评论:0      收藏:0      [点我收藏+]

惰性机制:Publisher.objects.all()或者.filter()等都只是返回了一个QuerySet(查询结果集对象),它并不会马上执行sql,而是当调用QuerySet的时候才执行sql,为了测试,我们加上 sql 日志。

在 settings.py 文件上修改

 1 # 在最后添加
 2 LOGGING = {
 3     version: 1,
 4     disable_existing_loggers: False,
 5     handlers: {
 6         console:{
 7             level:DEBUG,
 8             class:logging.StreamHandler,
 9         },
10     },
11     loggers: {
12         django.db.backends: {
13             handlers: [console],
14             propagate: True,
15             level:DEBUG,
16         },
17     }
18 }

在 views.py 上修改

 1 from django.shortcuts import render, HttpResponse
 2 from app01 import models
 3 from  app01.models import Book,Author,Publisher
 4  
 5 # Create your views here.
 6  
 7 def data_oper(req):
 8  
 9     obj_set = models.Book.objects.filter(id=2)
10  
11     return HttpResponse("Hello world")

浏览器访问 http://127.0.0.1:8000/data_oper/ 结果显示 sql 语句没有执行

技术分享图片

调用 QuerySet ,在 views.py 上修改

 1 rom django.shortcuts import render, HttpResponse
 2 from app01 import models
 3 from  app01.models import Book,Author,Publisher
 4  
 5 # Create your views here.
 6  
 7 def data_oper(req):
 8  
 9     obj_set = models.Book.objects.filter(id=2)
10     for obj in obj_set:
11         print(obj.title)
12  
13     return HttpResponse("Hello world")

浏览器访问 http://127.0.0.1:8000/data_oper/ 结果显示 sql 语句已执行

技术分享图片

Django中的惰性机制

原文:https://www.cnblogs.com/zyq6/p/11805905.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!