日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

优化SQL语句小结

發布時間:2025/6/17 数据库 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 优化SQL语句小结 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

基本的思路:

  • 優化更需要優化的Query
  • 定位優化對象的性能瓶頸(IO/CPU等)
  • 明確優化要達到的目標
  • 從Explain入手
  • 優化的基本原則

    1)? 永遠用小結果集驅動大結果集

    2)? 盡可能利用索引完成排序

    3)? 自取自己需要的字段

    4)? 僅僅使用最有效的過濾條件

    5)? 盡可能避免復雜的Join和子查詢。

    通過Query Profile查看一條Query獲取CPU、IO、IPC等資源消耗情況, 分析其性能瓶頸

    具體做法如下:

    1)? Set profiling=1 ????? 開啟Query Profiler功能

    2)? Show Profiles:獲取保存多個Query的Profile的概要信息

    3)? Show profile cpu, block io for query 6 針對單個Query獲取詳細的profile信息

    查找待優化的SQL

    (1)???? 通過show status和應用特點了解各種SQL的執行頻率

    通過SHOW STATUS可以提供服務器狀態信息,也可以使用mysqladmin extended-status命令獲得。SHOW STATUS可以根據需要顯示session級別的統計結果和global級別的統計結果。

    以下幾個參數對Myisam和Innodb存儲引擎都計數:

    1.Com_select? 執行select操作的次數,一次查詢只累加1;

    2.Com_insert 執行insert操作的次數,對于批量插入的insert操作,只累加一次;

    3.Com_update 執行update操作的次數;

    4.Com_delete 執行delete操作的次數;

    ?

    以下幾個參數是針對Innodb存儲引擎計數的,累加的算法也略有不同:

    1. Innodb_rows_read select查詢返回的行數;

    2. Innodb_rows_inserted執行Insert操作插入的行數;

    3. Innodb_rows_updated 執行update操作更新的行數;

    4. Innodb_rows_deleted 執行delete操作刪除的行數;

    通過以上幾個參數,可以很容易的了解當前數據庫的應用是以插入更新為主還是以查詢操作為主,以及各種類型的SQL大致的執行比例是多少。對于更新操作的計數,是對執行次數的計數,不論提交還是回滾都會累加。

    ?

    對于事務型的應用,通過Com_commit和Com_rollback可以了解事務提交和回滾的情況,對于回滾操作非常頻繁的數據庫,可能意味著應用編寫存在問題。

    此外,以下幾個參數便于我們了解數據庫的基本情況:

    1.Connections 試圖連接Mysql服務器的次數

    2.Uptime ?? 服務器工作時間

    3.Slow_queries 慢查詢的次數

    (2)???? 定位執行效率較低的SQL語句

    可以通過以下兩種方式定位執行效率較低的SQL語句:

    1.可以通過慢查詢日志定位那些執行效率較低的sql語句,用--log-slow-queries[=file_name]選項啟動時,mysqld寫一個包含所有執行時間超過long_query_time秒的SQL語句的日志文件。可以鏈接到管理維護中的相關章節。

    ?

    2.慢查詢日志在查詢結束以后才紀錄,所以在應用反映執行效率出現問題的時候查詢慢查詢日志并不能定位問題,可以使用show processlist命令查看當前MySQL在進行的線程,包括線程的狀態,是否鎖表等等,可以實時的查看SQL執行情況,同時對一些鎖表操作進行優化。

    ?

    (3)???? 通過EXPLAIN分析低效SQL的執行計劃

    通過以上步驟查詢到效率低的SQL后,我們可以通過explain或者desc 獲取MySQL如何執行SELECT語句的信息,包括select語句執行過程表如何連接和連接的次序。

    Explain可以知道什么時候必須為表加入索引以得到一個使用索引來尋找記錄的更快的SELECT。

    ?

    select_type:select 類型

    table:輸出結果集的表

    type:表示表的連接類型

    ①當表中僅有一行是type的值為system是最佳的連接類型;

    ②當select操作中使用索引進行表連接時type的值為ref;

    ③當select的表連接沒有使用索引時,經常會看到type的值為ALL,表示對該表進行了全表掃描,這時需要考慮通過創建索引來提高表連接的效率。

    possible_keys:表示查詢時,可以使用的索引列.

    key:表示使用的索引

    key_len:索引長度

    rows:掃描范圍

    Extra:執行情況的說明和描述

    (4)???? 確定問題,并采取相應的優化措施

    經過以上步驟,基本可以確認問題出現的原因,可以根據情況采取相應的措施,進行優化提高執行的效率。

    ?

    轉載于:https://www.cnblogs.com/mackxu/archive/2013/03/03/2942045.html

    《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

    總結

    以上是生活随笔為你收集整理的优化SQL语句小结的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 欧美人妻精品一区二区 | 国产乱淫av公 | a级片免费在线观看 | 亚洲国产成人无码av在线 | 亚洲bb| 亚洲天堂高清 | 女人张开双腿让男人捅 | 欧美图片一区二区 | 九九热视频在线播放 | 日韩精品一区二区三区在线视频 | 国产福利精品一区 | 无码精品人妻一区二区三区漫画 | 8mav在线| 一区二区三区黄 | 亚洲区在线 | 欧美无砖砖区免费 | 黄色av网| 国产欧美日韩中文字幕 | 黄片一区二区 | 久久免费偷拍视频 | 亚洲人女屁股眼交6 | 日韩av不卡电影 | 午夜小视频在线观看 | 18禁免费无码无遮挡不卡网站 | 欧美人与禽猛交乱配视频 | 欧美 日韩 国产 在线 | 日本亚洲一区二区 | 日韩一区在线观看视频 | 国产精品久久久久久久久免费 | 不卡av在线播放 | 在线观看jizz | 免费在线视频观看 | 精品国内自产拍在线观看视频 | 黄在线视频 | 欧美黑人性生活 | 国产又粗又猛又爽又黄的视频在线观看动漫 | 男女激情视频网站 | 在线亚洲色图 | 黄色一集片 | 久久中文视频 | 欧美婷婷精品激情 | a级网站在线观看 | 美女写真福利视频 | 探花国产在线 | 激情狠狠| 国语对白一区二区 | av毛片网站 | 色综合av| xxxxhdvideos| av网址在线免费观看 | 日本视频在线看 | 在线观看视频一区二区三区 | 国产亚洲精品久久久久动 | 热播之家 | 黑人3p波多野结衣在线观看 | eeuss国产一区二区三区黑人 | 色就是色网站 | 久久久久中文字幕亚洲精品 | 51精品国自产在线 | 成年人在线视频观看 | 天天操网 | 小向美奈子在线观看 | 蜜芽在线视频 | 18深夜在线观看免费视频 | 99资源站 | 国产综合激情 | 999国产 | 黄色片在哪看 | 樱花动漫无圣光 | 欧美视频在线一区二区三区 | 国产chinesehd精品 | 禁久久精品乱码 | 日本公妇乱偷中文字幕 | 成人永久免费视频 | 久色在线 | 黄色一级片一级片 | www视频免费在线观看 | 久久免费看视频 | 草草影院第一页yycc.com | www.色国产| 国产网红无码精品视频 | 乐播av一区二区三区 | 牛牛视频在线 | 丰满大乳国产精品 | 亚洲熟女一区二区 | 日韩欧美亚洲一区二区 | a毛片在线免费观看 | 肉丝美脚视频一区二区 | 人妻丰满熟妇av无码区不卡 | 久久精品国产亚洲AV高清综合 | 国产黄色影视 | 亚洲无套| 九月婷婷 | 国产精品高清无码 | 欧美裸体精品 | 91黄色在线视频 | 亚洲天堂123 | 91桃色免费视频 | 蜜臀视频在线观看 |