91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django中怎么查看ORM執行的SQL語句

發布時間:2021-07-24 11:44:38 來源:億速云 閱讀:286 作者:Leah 欄目:大數據

本篇文章給大家分享的是有關Django中怎么查看ORM執行的SQL語句,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

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語句,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

报价| 自治县| 绥宁县| 开原市| 巴楚县| 湖口县| 庐江县| 双流县| 长武县| 绵竹市| 武陟县| 余干县| 武城县| 顺平县| 南江县| 闸北区| 镇原县| 鸡泽县| 太仓市| 高安市| 胶南市| 汤阴县| 资溪县| 保靖县| 松滋市| 鄂州市| 庐江县| 北宁市| 历史| 丹凤县| 石门县| 揭东县| 靖安县| 溧阳市| 北海市| 金乡县| 博爱县| 尖扎县| 江西省| 永善县| 商都县|