如何查看Django ORM执行的SQL语句
程序员文章站
2022-06-28 19:09:14
Django ORM对数据库操作的封装相当完善,日常大部分数据库操作都可以通过ORM实现。但django将查询过程隐藏在了后台,这在开发时可能会略显晦涩,并且使用方式不当还会造成开销过大。 那么如何查看django何时执行了什么sql语句呢?答案是使用Logging。 先直接上方法,在setting ......
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模块执行系统日志记录。
本文首发于bigyoung小站
推荐阅读
-
Mybaits 源码解析 (六)----- 全网最详细:Select 语句的执行过程分析(上篇)(Mapper方法是如何调用到XML中的SQL的?)
-
探讨:Oracle数据库查看一个进程是如何执行相关的实际SQL语句
-
mysql实战45讲读书笔记(一) 一条SQL查询语句是如何执行的
-
SQLServer怎么查看正在执行的SQL语句?
-
oracle查看执行最慢与查询次数最多的sql语句
-
获取django框架orm query执行的sql语句实现方法分析
-
如何让docker中的mysql启动时自动执行sql语句
-
SQL Server查看Sql语句执行的耗时和IO消耗
-
mybatis如何直接执行传入的任意sql语句,并按照顺序取出查询的结果集
-
一条SQL查询、更新语句是如何执行的(基础架构,日志系统)