国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

如何查看Django ORM執行的SQL語句的實現

瀏覽:38日期:2024-10-10 14:07:00

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語句內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Django
相關文章:
主站蜘蛛池模板: 九九干| 国产精品国产三级国产an不卡 | 亚洲专区一 | 日韩一级性生活片 | 亚洲一区成人 | 一区二区三区四区在线视频 | 欧美国产一区二区三区 | 杨晨晨福利视频 | 欧美黑人性xxx猛交 欧美很黄视频在线观看 | 亚洲天堂视频一区 | 一级毛片免费不卡 | 日本高清色本在线www游戏 | 美女的让男人桶到爽软件 | 欧美jizzhd欧美精品 | 怡红院免费在线视频 | 国产精品国内免费一区二区三区 | 欧美日韩一区二区三区视频在线观看 | 特别福利视频在线观看 | 美国三级大片 | 久草资源网 | 成人午夜大片免费7777 | 成人在线中文字幕 | 91久久国产露脸精品免费 | 色综合亚洲七七久久桃花影院 | 欧美日韩亚洲综合在线一区二区 | 中文字幕亚洲精品日韩精品 | 欧美视频一区二区三区 | 精品视频免费在线 | 男女午夜视频在线观看 | 亚洲精品视频在线观看免费 | 在线观看视频一区二区三区 | 亚洲一区二区影院 | 欧美日韩中文字幕在线视频 | 久久亚洲国产高清 | 日韩欧美精品一区二区 | 女人让男人桶的小视频 | 久久精品国产精品亚洲20 | 国内精品美女写真视频 | 99久久精品免费精品国产 | 免费a级毛片无码 | 国产成人免费在线观看 |