如何查看Django ORM執(zhí)行的SQL語句的實(shí)現(xiàn)
Django ORM對數(shù)據(jù)庫操作的封裝相當(dāng)完善,日常大部分?jǐn)?shù)據(jù)庫操作都可以通過ORM實(shí)現(xiàn)。但django將查詢過程隱藏在了后臺(tái),這在開發(fā)時(shí)可能會(huì)略顯晦澀,并且使用方式不當(dāng)還會(huì)造成開銷過大。
那么如何查看django何時(shí)執(zhí)行了什么sql語句呢?答案是使用Logging。
先直接上方法,在settings.py中加入LOGGING選項(xiàng),調(diào)整logging等級(jí)為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',
},
},
}
然后啟動(dòng)runserver,瀏覽需要訪問數(shù)據(jù)庫的頁面,在shell中即可看見相關(guān)日志,如下:
[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
上面打印出的日志是我的博客首頁獲取前十篇文章時(shí)所執(zhí)行的部分SQL語句,其對應(yīng)的QuerySet為
Article.objects.filter(pub_date__lt=timezone.now())[:10] \
.defer('author', 'category__number') \
.select_related('category') \
.prefetch_related('topics')
通過Logging不僅可以查看SQL語句,還可以由此知道django何時(shí)執(zhí)行了SQL。在某些情況下我們可以通過這種方式判斷,后臺(tái)是否重復(fù)執(zhí)行了SQL語句,便于指導(dǎo)數(shù)據(jù)庫訪問優(yōu)化。
Django使用Python的內(nèi)建的logging模塊執(zhí)行系統(tǒng)日志記錄。
到此這篇關(guān)于如何查看Django ORM執(zhí)行的SQL語句的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Django ORM執(zhí)行SQL語句內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
云原生Docker部署Django和mysql項(xiàng)目全過程
最近在學(xué)習(xí)用docker部署Django項(xiàng)目,經(jīng)過百折不撓的鼓搗,終于將項(xiàng)目部署成功,下面這篇文章主要給大家介紹了關(guān)于云原生Docker部署Django和mysql項(xiàng)目的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12
在python中使用pymysql往mysql數(shù)據(jù)庫中插入(insert)數(shù)據(jù)實(shí)例
今天小編就為大家分享一篇在python中使用pymysql往mysql數(shù)據(jù)庫中插入(insert)數(shù)據(jù)實(shí)例。具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03
python如何實(shí)現(xiàn)word批量轉(zhuǎn)HTML
這篇文章主要介紹了python如何實(shí)現(xiàn)word批量轉(zhuǎn)HTML,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下2020-09-09
python項(xiàng)目127.0.0.1:5000訪問失敗問題解決
Windows環(huán)境下啟動(dòng)python項(xiàng)目,接口訪問失敗,本文給大家分享python項(xiàng)目127.0.0.1:5000訪問失敗問題解決方法,感興趣的朋友跟隨小編一起看看吧2023-09-09
Python利用operator模塊實(shí)現(xiàn)對象的多級(jí)排序詳解
python中的operator模塊提供了一系列的函數(shù)操作。下面這篇文章主要給大家介紹了在Python中利用operator模塊實(shí)現(xiàn)對象的多級(jí)排序的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-05-05
python如何將兩個(gè)數(shù)據(jù)表中的對應(yīng)數(shù)據(jù)相加
這篇文章主要介紹了python如何將兩個(gè)數(shù)據(jù)表中的對應(yīng)數(shù)據(jù)相加問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
Python處理和解析CLIXML數(shù)據(jù)的方法
在使用Windows的Windows Remote Management (WinRM)服務(wù)與PowerShell交互時(shí),經(jīng)常會(huì)遇到CLIXML(即CLI XML)格式的數(shù)據(jù),本文將介紹如何在Python中處理和解析CLIXML數(shù)據(jù),并提供一種方法來從數(shù)據(jù)中提取有效信息,需要的朋友可以參考下2024-04-04

