Django 惰性机制

惰性机制:Publisher.Book.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
 
def temp(requset):
 
obj1 = models.Book.objects.filter(id=1)
 
return HttpResponse("我是函数temp")

 

浏览器访问 http://127.0.0.1:8080/temp 结果显示 sql 语句没有执行
1334255-20190522155052823-27335043.png

将函数进行一些修改

在 views.py 上调用 obj1对象

def temp(requset):
 
    obj1= models.Book.objects.filter(id=2)
    for obj in obj1:
        print(obj.title)
 
    return HttpResponse("我是temp函数")

浏览器访问 http://127.0.0.1:8000/temp/ 结果显示 sql 语句已执行
1334255-20190522155220380-540979688.png

posted @ 2019-11-04 09:04  lovelife80  阅读(124)  评论(0编辑  收藏  举报