如何查看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 字符串中的字符倒转
Sep 06 Python
Python自动化测试工具Splinter简介和使用实例
May 13 Python
由Python运算π的值深入Python中科学计算的实现
Apr 17 Python
Python检测一个对象是否为字符串类的方法
May 21 Python
解密Python中的描述符(descriptor)
Jun 03 Python
Python+tkinter模拟“记住我”自动登录实例代码
Jan 16 Python
python 字符串追加实例
Jul 20 Python
配置python的编程环境之Anaconda + VSCode的教程
Mar 29 Python
Python Pandas list列表数据列拆分成多行的方法实现
Dec 14 Python
全网最细 Python 格式化输出用法讲解(推荐)
Jan 18 Python
python利用opencv实现颜色检测
Feb 23 Python
Python OpenCV 彩色与灰度图像的转换实现
Jun 05 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-fpm.service not found问题的办法
2017/06/06 PHP
php layui实现前端多图上传实例
2019/07/30 PHP
Jquery Ajax.ashx 高效分页实现代码
2009/10/20 Javascript
jquery text()要注意啦
2009/10/30 Javascript
jquery validator 插件增加日期比较方法
2010/02/21 Javascript
JS setCapture 区域外事件捕捉
2010/03/18 Javascript
js 验证密码强弱的小例子
2013/03/21 Javascript
使用JavaScript获取地址栏参数的方法
2014/12/19 Javascript
jQuery中:disabled选择器用法实例
2015/01/04 Javascript
Javascript获取数组中的最大值和最小值的方法汇总
2016/01/01 Javascript
js字符串截取函数slice、substring和substr的比较
2016/05/17 Javascript
利用js查找数组中指定元素并返回该元素的所有索引示例
2017/03/29 Javascript
vue + element-ui实现简洁的导入导出功能
2017/12/22 Javascript
select获取下拉框的值 下拉框默认选中方法
2018/02/28 Javascript
Javascript实现鼠标点击冒泡特效
2019/12/24 Javascript
详解Vue中Axios封装API接口的思路及方法
2020/10/10 Javascript
python自定义解析简单xml格式文件的方法
2015/05/11 Python
在Python中用has_key()方法查找键是否存在的教程
2015/05/21 Python
Python批量修改文本文件内容的方法
2016/04/29 Python
Python使用win32 COM实现Excel的写入与保存功能示例
2018/05/03 Python
Python实现的在特定目录下导入模块功能分析
2019/02/11 Python
Python判断两个文件是否相同与两个文本进行相同项筛选的方法
2019/03/01 Python
PyTorch之图像和Tensor填充的实例
2019/08/18 Python
Python搭建代理IP池实现获取IP的方法
2019/10/27 Python
Python Sphinx使用实例及问题解决
2020/01/17 Python
python游戏开发的五个案例分享
2020/03/09 Python
PyCharm2019.3永久激活破解详细图文教程,亲测可用(不定期更新)
2020/10/29 Python
快速解决pymongo操作mongodb的时区问题
2020/12/05 Python
python中pdb模块实例用法
2021/01/15 Python
《充气雨衣》教学反思
2014/04/07 职场文书
县委班子四风对照检查材料思想汇报
2014/09/29 职场文书
销售员岗位职责范本
2015/04/11 职场文书
2016党员学习《反对自由主义》心得体会
2016/01/22 职场文书
《比的意义》教学反思
2016/02/18 职场文书
先进基层党组织事迹材料2016
2016/02/29 职场文书
纯html+css实现Element loading效果
2021/08/02 HTML / CSS