栏目分类:
子分类:
返回
终身学习网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
终身学习网 > IT > 软件开发 > 后端开发 > Python > python框架

Django之惰性机制相关介绍

python框架 更新时间:发布时间: 百科书网 趣学号

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 语句已执行。

转载请注明:文章转载自 www.051e.com
本文地址:http://www.051e.com/it/13043.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 ©2023-2025 051e.com

ICP备案号:京ICP备12030808号