Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Django 惰性机制

Django 惰性机制

作者头像
py3study
发布于 2020-01-16 07:54:40
发布于 2020-01-16 07:54:40
36500
代码可运行
举报
文章被收录于专栏:python3python3
运行总次数:0
代码可运行

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

在 settings.py 文件上修改

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 在最后添加
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 上修改

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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 上修改

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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 语句已执行

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/06/07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Django ORM (四) annot
可以通过计算查询结果中每一个对象所关联的对象集合,从而得出总计值(也可以是平均值或总和),即为查询集的每一项生成聚合。
py3study
2020/01/16
3560
django--ORM的单表操作
它的作用相当于 在该app下建立 migrations目录,并记录下你所有的关于modes.py的改动,比如0001_initial.py, 但是这个改动还没有作用到数据库文件
py3study
2018/08/03
1K0
Django ORM (三) 查询,删除
ORM 查询操作 修改 views.py 文件 from django.shortcuts import render, HttpResponse from app01 import models from app01.models import Book,Author,Publisher def data_oper(req): # 获取 book 表 id 为2的价格 book = models.Book.objects.filter(id=2).values("price")
py3study
2020/01/15
1.3K0
django 实现
Title 1.输入信息,在底部输出用户输入的信息(数据存储在数据库中) urls.py from django.contrib import admin from django.urls import path from first import views urlpatterns = [ path('admin/', admin.site.urls), path('info/', views.show_info), path('userInfo', views.show_us
py3study
2020/01/19
3350
Django ORM 单表操作
返回的是 QuerySet 类型数据,类似于 list,里面放的是满足条件的模型类的对象,可用索引下标取出模型类的对象;
HammerZe
2022/03/25
1.4K0
Django ORM 单表操作
第十九章 Django的ORM映射机制
第十九章 Django的ORM映射机制 第一课 Django获取多个数据以及文件上传 1.获取多选的结果(checkbox,select/option)时: req.POST.getlist('favor')获取一个列表 2.上传文件: 前端html中: <form action='/login' method='POST' enctype='multipart/form-data'> 后端接收: if req.method=='POST':
玩蛇的胖纸
2018/06/08
9680
Django 学习笔记之模型(下)
上篇文章讲解了 Django 如何创建模型,本文将继续讲解如何对模型进行增删改查操作。
猴哥yuri
2018/08/16
6830
Django学习笔记之Models与ORM操作
一、ORM增加 from django.db import models class Publisher(models.Model): name = models.CharField(max_length=30, verbose_name="名称") address = models.CharField("地址", max_length=50) city = models.CharField('城市',max_length=60) state_province = model
Jetpropelledsnake21
2018/07/05
1.2K0
Django——图书管理系统(七)
前文,我已经介绍过了外键。本文将介绍,在带有外键的情形下,如何实现增删改查的。图书管理系统现在已经可以管理出版社了,这一步就是管理书籍。鉴于前面的一系列文章已经介绍过了出版社是如何增删改查的,本次就直接上代码,展示效果。
zy010101
2021/01/29
3451
Django orm(1)
为了方便我们测试SQL语句,我们需要配置一下tests.py文件,在这里测试我们的SQL语句,单独测试Django中的py文件都可以这样配置。
GH
2019/12/16
4340
Python进阶29-ORM介绍
-多年互联网运维工作经验,曾负责过大规模集群架构自动化运维管理工作。 -擅长Web集群架构与自动化运维,曾负责国内某大型金融公司运维工作。 -devops项目经理兼DBA。 -开发过一套自动化运维平台(功能如下): 1)整合了各个公有云API,自主创建云主机。 2)ELK自动化收集日志功能。 3)Saltstack自动化运维统一配置管理工具。 4)Git、Jenkins自动化代码上线及自动化测试平台。 5)堡垒机,连接Linux、Windows平台及日志审计。 6)SQL执行及审批流程。 7)慢查询日志分析web界面。
DriverZeng
2022/09/26
4.6K0
Python进阶29-ORM介绍
Django ORM那些相关操作
一般操作 https://docs.djangoproject.com/en/1.11/ref/models/querysets/         官网文档 常用的操作 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。 <4> e
新人小试
2018/04/12
2.4K0
Django之ORM数据库
            django默认使用sqlite的数据库,默认自带sqlite的数据库驱动 , 引擎名称:django.db.backends.sqlite3
超蛋lhy
2018/08/31
2.6K0
Django之ORM数据库
Django学习笔记之Django ORM相关操作
<!-- p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px "PingFang SC"; color: #000000 } span.s1 { } span.s2 { font: 11.0px Helvetica } -->
Jetpropelledsnake21
2019/02/15
3.7K0
Django 模版语法 二
如果值是False,就替换成设置的默认值,否则就是用本来的值 在 views.py 中修改
py3study
2020/01/16
2750
ORM常用操作
对于ForeignKey对象,clear()和remove()方法仅在null=True时存在
全栈程序员站长
2022/07/21
2.1K0
python 终级篇 django --
                                   一般操作                                             
py3study
2020/01/19
2.9K0
python 终级篇 django --
【Django】当大型项目采用Django框架对于QueryDict以及模板的表单在Admin 管理工具的使用
在HttpRequest对象中,GET和POST属性是django.http的实例。QueryDict类。 QueryDict是一个用户定义的类,类似于字典。它用于处理单个键对应多个值的情况。 QueryDict实现所有标准字典方法。它还包括一些独特的方法:
上进小菜猪
2022/12/13
1.7K0
【Django】当大型项目采用Django框架对于QueryDict以及模板的表单在Admin 管理工具的使用
Django---ORM操作大全
前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行数据库操作 ORM是什么?:(在django中,根据代码中的类自动生成数据库的表也叫--code first) ORM:Object Relational Mapping(关系对象映射) 类名对应------》数据库中的表名 类属性
用户1214487
2018/01/24
7K1
Django---ORM操作大全
Python框架:Django写图书管理系统(LMS)
今天我会带大家真正写一个Django项目,对于入门来说是有点难度的,因为逻辑比较复杂,但是真正的知识就是函数与面向对象,这也是培养用Django思维写项目的开始
小小科
2018/07/31
1.7K0
Python框架:Django写图书管理系统(LMS)
相关推荐
Django ORM (四) annot
更多 >
领券
💥开发者 MCP广场重磅上线!
精选全网热门MCP server,让你的AI更好用 🚀
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验