如何查看Django ORM执行的SQL语句的实现


Posted in Python onApril 20, 2020

Django ORM对数据库操作的封装相当完善,日常大部分数据库操作都可以通过ORM实现。但django将查询过程隐藏在了后台,这在开发时可能会略显晦涩,并且使用方式不当还会造成开销过大。

那么如何查看django何时执行了什么sql语句呢?答案是使用Logging。

先直接上方法,在settings.py中加入LOGGING选项,调整logging等级为DEBUG即可:

LOGGING = {
  'version': 1,
  'disable_existing_loggers': False,
  'formatters': {
    'simple': {
      'format': '[%(asctime)s] %(message)s'
    },
  },
  'handlers': {
    'console': {
      'level': 'DEBUG',
      'class': 'logging.StreamHandler',
      'formatter': 'simple'
    },
  },
  'loggers': {
    'django': {
      'handlers': ['console'],
      'level': 'DEBUG',
    },
  },
}

然后启动runserver,浏览需要访问数据库的页面,在shell中即可看见相关日志,如下:

[2018-04-21 21:09:14,676] (0.002) SELECT `blog_article`.`id`, `blog_article`.`title`, `blog_article`.`cover`, `blog_article`.`content`, `blog_article`.`pub_date`, `blog_article`.`category_id`, `blog_article`.`views`, `blog_category`.`id`, `blog_category`.`name` FROM `blog_article` INNER JOIN `blog_category` ON (`blog_article`.`category_id` = `blog_category`.`id`) WHERE `blog_article`.`pub_date` < '2018-04-21 13:09:14.601856' ORDER BY `blog_article`.`pub_date` DESC LIMIT 10; args=('2018-04-21 13:09:14.601856',)
[2018-04-21 21:09:14,678] (0.000) SELECT (`blog_article_topics`.`article_id`) AS `_prefetch_related_val_article_id`, `blog_topic`.`id`, `blog_topic`.`name`, `blog_topic`.`number` FROM `blog_topic` INNER JOIN `blog_article_topics` ON (`blog_topic`.`id` = `blog_article_topics`.`topic_id`) WHERE `blog_article_topics`.`article_id` IN (3, 4, 5, 6, 7, 8, 9, 10, 11, 12) ORDER BY `blog_topic`.`number` ASC; args=(3, 4, 5, 6, 7, 8, 9, 10, 11, 12)
[2018-04-21 21:09:14,708] "GET / HTTP/1.1" 200 22325

上面打印出的日志是我的博客首页获取前十篇文章时所执行的部分SQL语句,其对应的QuerySet为

Article.objects.filter(pub_date__lt=timezone.now())[:10] \
.defer('author', 'category__number') \
.select_related('category') \
.prefetch_related('topics')

通过Logging不仅可以查看SQL语句,还可以由此知道django何时执行了SQL。在某些情况下我们可以通过这种方式判断,后台是否重复执行了SQL语句,便于指导数据库访问优化。

Django使用Python的内建的logging模块执行系统日志记录。

到此这篇关于如何查看Django ORM执行的SQL语句的实现的文章就介绍到这了,更多相关Django ORM执行SQL语句内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
利用Python脚本实现ping百度和google的方法
Jan 24 Python
Python 文件操作的详解及实例
Sep 18 Python
深入理解Python单元测试unittest的使用示例
Nov 18 Python
Python中的并发处理之asyncio包使用的详解
Apr 03 Python
python3.6.3转化为win-exe文件发布的方法
Oct 31 Python
Python的log日志功能及设置方法
Jul 11 Python
Django框架基础模板标签与filter使用方法详解
Jul 23 Python
Python (Win)readline和tab补全的安装方法
Aug 27 Python
python 如何将数据写入本地txt文本文件的实现方法
Sep 11 Python
selenium+python配置chrome浏览器的选项的实现
Mar 18 Python
五分钟带你搞懂python 迭代器与生成器
Aug 30 Python
python引入其他文件夹下的py文件具体方法
May 23 Python
使用IPython或Spyder将省略号表示的内容完整输出
Apr 20 #Python
解决Python spyder显示不全df列和行的问题
Apr 20 #Python
Python爬虫实现vip电影下载的示例代码
Apr 20 #Python
TensorFlow tf.nn.softmax_cross_entropy_with_logits的用法
Apr 19 #Python
tensorflow中tf.reduce_mean函数的使用
Apr 19 #Python
TensorFlow打印输出tensor的值
Apr 19 #Python
numpy库reshape用法详解
Apr 19 #Python
You might like
用PHP动态创建Flash动画
2006/10/09 PHP
?生?D片??C字串
2006/12/06 PHP
Smarty Foreach 使用说明
2010/03/23 PHP
shopex主机报错误请求解决方案(No such file or directory)
2011/12/27 PHP
php_screw安装使用教程(另一个PHP代码加密实现)
2014/05/29 PHP
phpExcel中文帮助手册之常用功能指南
2014/08/18 PHP
PHP简单实现DES加密解密的方法
2016/07/12 PHP
php实现文件上传及头像预览功能
2017/01/15 PHP
javascript实现动态CSS换肤技术的脚本
2007/06/29 Javascript
jQuery中removeData()方法用法实例
2014/12/27 Javascript
javascript简单实现类似QQ头像弹出效果的方法
2015/08/03 Javascript
浅谈JavaScript中的对象及Promise对象的实现
2015/11/15 Javascript
Node.js程序中的本地文件操作用法小结
2016/03/06 Javascript
ui组件之input多选下拉实现方法(带有搜索功能)
2016/07/14 Javascript
总结在前端排序中遇到的问题
2016/07/19 Javascript
微信小程序tabbar底部导航
2018/11/05 Javascript
vue项目中使用fetch的实现方法
2019/04/25 Javascript
微信小程序 拍照或从相册选取图片上传代码实例
2019/08/28 Javascript
初学vue出现空格警告的原因及其解决方案
2019/10/31 Javascript
vue created钩子函数与mounted钩子函数的用法区别
2020/11/05 Javascript
[01:07:13]TNC vs Pain 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
Python中字符串对齐方法介绍
2015/05/21 Python
Python之pandas读写文件乱码的解决方法
2018/04/20 Python
python 利用pandas将arff文件转csv文件的方法
2019/02/12 Python
python常用数据重复项处理方法
2019/11/22 Python
opencv3/python 鼠标响应操作详解
2019/12/11 Python
python 实现socket服务端并发的四种方式
2020/12/14 Python
欧舒丹比利时官网:L’OCCITANE比利时
2017/04/25 全球购物
英国团购网站:Groupon英国
2017/11/28 全球购物
爱他美官方海外旗舰店:Aptamil奶粉
2017/12/22 全球购物
有限责任公司股东合作协议书范本
2014/10/30 职场文书
幼儿园个人总结
2015/02/28 职场文书
2015最新婚礼主持词
2015/06/30 职场文书
2016感恩父亲节主题广播稿
2015/12/18 职场文书
python requests模块的使用示例
2021/04/07 Python
nginx从安装到配置详细说明(安装,安全配置,防盗链,动静分离,配置 HTTPS,性能优化)
2022/02/12 Servers