成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

Mysql優化神器(推薦)

瀏覽:10日期:2023-10-07 16:40:28
前言

今天逛github時,發現了這款對 SQL 進行優化和改寫的自動化工具sora。感覺挺不錯的,就下載學習了一下。這個工具支持的功能比較多,可以作為我們日常開發中的一款輔助工具,現在我就把它推薦給你們~~~

github傳送門:https://github.com/XiaoMi/soar

背景

在我們日常開發中,優化SQL總是我們日常開發任務之一。例行 SQL 優化,不僅可以提升程序性能,還能夠降低線上故障的概率。

目前常用的 SQL 優化方式包括但不限于:業務層優化、SQL邏輯優化、索引優化等。其中索引優化通常通過調整索引或新增索引從而達到 SQL 優化的目的。索引優化往往可以在短時間內產生非常巨大的效果。如果能夠將索引優化轉化成工具化、標準化的流程,減少人工介入的工作量,無疑會大大提高我們的工作效率。

SOAR(SQL Optimizer And Rewriter) 是一個對 SQL 進行優化和改寫的自動化工具。由小米人工智能與云平臺的數據庫團隊開發與維護。

與業內其他優秀產品對比如下:

SOAR sqlcheck pt-query-advisor SQL Advisor Inception sqlautoreview 啟發式建議 ✔️ ✔️ ✔️ ❌ ✔️ ✔️ 索引建議 ✔️ ❌ ❌ ✔️ ❌ ✔️ 查詢重寫 ✔️ ❌ ❌ ❌ ❌ ❌ 執行計劃展示 ✔️ ❌ ❌ ❌ ❌ ❌ Profiling ✔️ ❌ ❌ ❌ ❌ ❌ Trace ✔️ ❌ ❌ ❌ ❌ ❌ SQL在線執行 ❌ ❌ ❌ ❌ ✔️ ❌ 數據備份 ❌ ❌ ❌ ❌ ✔️ ❌

從上圖可以看出,支持的功能豐富,其功能特點如下:

跨平臺支持(支持 Linux, Mac 環境,Windows 環境理論上也支持,不過未全面測試) 目前只支持 MySQL 語法族協議的 SQL 優化 支持基于啟發式算法的語句優化 支持復雜查詢的多列索引優化(UPDATE, INSERT, DELETE, SELECT) 支持 EXPLAIN 信息豐富解讀 支持 SQL 指紋、壓縮和美化 支持同一張表多條 ALTER 請求合并 支持自定義規則的 SQL 改寫

就介紹這么多吧,既然是SQL優化工具,光說是沒有用的,我們還是先用起來看看效果吧。

安裝

這里有兩種安裝方式,如下:

下載二進制安裝包

$ wget https://github.com/XiaoMi/soar/releases/download/0.11.0/soar.linux-amd64 -O soarchmod a+x soar

這里建議直接下載最新版,要不會有bug。

下載好的二進制文件添加到環境變量中即可(不會的谷歌一下吧,這里就不講了)。

測試一下:

$ echo ’select * from user’ | soar.darwin-amd64(根據你自己的二進制文件名來輸入)# Query: AC4262B5AF150CB5 ★ ★ ★ ☆ ☆ 75分 ```sqlSELECT *FROM USER``` ## 最外層 SELECT 未指定 WHERE 條件 * **Item:** CLA.001 * **Severity:** L4 * **Content:** SELECT 語句沒有 WHERE 子句,可能檢查比預期更多的行(全表掃描)。對于 SELECT COUNT(*) 類型的請求如果不要求精度,建議使用 SHOW TABLE STATUS 或 EXPLAIN 替代。 ## 不建議使用 SELECT * 類型查詢 * **Item:** COL.001 * **Severity:** L1 * **Content:** 當表結構變更時,使用 * 通配符選擇所有列將導致查詢的含義和行為會發生更改,可能導致查詢返回更多的數據。

源碼安裝

依賴環境:

1. Go 1.10+2. git

高級依賴(僅面向開發人員)

mysql 客戶端版本需要與容器中MySQL版本相同,避免出現由于認證原因導致無法連接問題 docker MySQL Server測試容器管理 govendor Go包管理 retool 依賴外部代碼質量靜態檢查工具二進制文件管理

生成二進制文件:

go get -d github.com/XiaoMi/soarcd ${GOPATH}/src/github.com/XiaoMi/soar && make生成的二進制文件與上面一樣,直接放入環境變量即可,這里我沒有嘗試,靠你們自己踩坑了呦~~~

簡單使用

0. 前置準備

準備一個table,如下:

CREATE TABLE `users` ( `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, `username` varchar(64) NOT NULL DEFAULT ’’, `nickname` varchar(255) DEFAULT ’’, `password` varchar(256) NOT NULL DEFAULT ’’, `salt` varchar(48) NOT NULL DEFAULT ’’, `avatar` varchar(128) DEFAULT NULL, `uptime` datetime DEFAULT NULL, PRIMARY KEY (`id`), UNIQUE KEY `username` (`username`)) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8mb4

1. 直接輸入sql語句(不運行)

$ echo 'select * from users' | soar.darwin-amd64$ # Query: 30AFCB1E1344BEBD ★ ★ ★ ☆ ☆ 75分 ```sqlSELECT *FROM users```## 最外層 SELECT 未指定 WHERE 條件 * **Item:** CLA.001 * **Severity:** L4 * **Content:** SELECT 語句沒有 WHERE 子句,可能檢查比預期更多的行(全表掃描)。對于 SELECT COUNT(*) 類型的請求如果不要求精度,建議使用 SHOW TABLE STATUS 或 EXPLAIN 替代。 ## 不建議使用 SELECT * 類型查詢 * **Item:** COL.001 * **Severity:** L1 * **Content:** 當表結構變更時,使用 * 通配符選擇所有列將導致查詢的含義和行為會發生更改,可能導致查詢返回更多的數據。

現在是完全根據SQL語句進行分析的,因為沒有連接到mysql。可以看到,給出的報告也很詳細,但是只是空殼子,僅憑SQL語句給出的分析并不是準確的,所以我們開始接下來的應用。

2. 連接mysql生成EXPLAIN分析報告

我們可以在配置文件中配置好mysql相關的配置,操作如下:

vi soar.yaml# yaml format config fileonline-dsn: addr: 127.0.0.1:3306 schema: asong user: root password: root1997 disable: false test-dsn: addr: 127.0.0.1:3306 schema: asong user: root password: root1997 disable: false

配置好了,我們來實踐一下子吧:

$ echo 'SELECT id,username,nickname,password,salt,avatar,uptime FROM users WHERE username = ’asong1111’' | soar.darwin-amd64 -test-dsn='root:root1997@127.0.0.1:3306/asong' -allow-online-as-test -log-output=soar.log$ # Query: D12A420193AD1674 ★ ★ ★ ★ ★ 100分 ```sqlSELECT id, username, nickname, PASSWORD, salt, avatar, uptimeFROM usersWHERE username = ’asong1111’``` ## Explain信息 | id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | scalability | Extra ||---|---|---|---|---|---|---|---|---|---|---|---|---|| 1 | SIMPLE | *users* | NULL | const | username | username | 258 | const | 1 | ☠️ **100.00%** | ☠️ **O(n)** | NULL | ### Explain信息解讀 #### SelectType信息解讀 * **SIMPLE**: 簡單SELECT(不使用UNION或子查詢等). #### Type信息解讀 * **const**: const用于使用常數值比較PRIMARY KEY時, 當查詢的表僅有一行時, 使用system. 例:SELECT * FROM tbl WHERE col = 1.

這回結果中多了EXPLAIN信息分析報告。這對于剛開始入門的小伙伴們是友好的,因為我們對Explain解析的字段并不熟悉,有了它我們可以完美的分析SQL中的問題,是不是很棒。

3. 語法檢查

soar工具不僅僅可以進行sql語句分析,還可以進行對sql語法進行檢查,找出其中的問題,來看個例子:

$ echo 'selec * from users' | soar.darwin-amd64 -only-syntax-checkAt SQL 1 : line 1 column 5 near 'selec * from users' (total length 18)

這里select關鍵字少了一個t,運行該指令幫助我們一下就定位了問題,當我們的sql語句很長時,就可以使用該指令來輔助我們檢查SQL語句是否正確。

4. SQL美化

我們日常開發時,經常會看其他人寫的代碼,因為水平不一樣,所以有些SQL語句會寫的很亂,所以這個工具就派上用場了,我們可以把我們的SQL語句變得漂亮一些,更容易我們理解哦。

$ echo 'SELECT id,username,nickname,password,salt,avatar,uptime FROM users WHERE username = ’asong1111’' | soar.darwin-amd64 -report-type=pretty SELECT id, username, nickname, PASSWORD, salt, avatar, uptimeFROM usersWHERE username = ’asong1111’;

這樣看起來是不是更直觀了呢~~。

結尾

因為我也才是剛使用這個工具,更多的玩法我還沒有發現,以后補充。更多玩法可以自己研究一下,github傳送門:https://github.com/XiaoMi/soar。官方文檔其實很粗糙,更多方法解鎖還要靠自己研究,畢竟源碼已經給我們了,對于學習go也有一定幫助,當作一個小項目慢慢優化豈不是更好呢~~。

到此這篇關于Mysql優化神器(推薦)的文章就介紹到這了,更多相關Mysql優化內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
91尤物视频在线观看| 蜜桃av噜噜一区| 一区二区三区中文字幕在线观看| av在线播放成人| 日韩一区二区三区电影在线观看 | 黑人巨大精品欧美黑白配亚洲| 蘑菇福利视频一区播放| 亚洲欧美日韩国产成人精品影院| 91在线观看美女| 精品精品欲导航| www.视频一区| 日韩欧美一区在线观看| 国产麻豆视频一区二区| 884aa四虎影成人精品一区| 美女视频黄频大全不卡视频在线播放| 色妹子一区二区| 视频一区在线播放| 久久久噜噜噜久久狠狠50岁| 偷窥国产亚洲免费视频| 久久成人资源| 亚洲国产精品久久人人爱蜜臀| 亚洲日本国产| 日韩一区欧美一区| 亚洲国产精品第一区二区| 国产蜜臀97一区二区三区 | 日日摸夜夜添夜夜添精品视频 | 久久精品久久99精品久久| 欧美在线观看一区二区| 蜜桃久久久久久| 欧美三级午夜理伦三级中视频| 极品美女销魂一区二区三区免费| 欧美一区二区三区四区视频| 成人黄页毛片网站| 久久一夜天堂av一区二区三区 | 日本成人在线不卡视频| 欧美三级日韩三级| 国产精品99久久久久久久女警| 日韩欧美亚洲另类制服综合在线| 岛国一区二区在线观看| 久久精品欧美一区二区三区不卡 | 欧美成人精品| 亚洲欧美日韩久久| 亚洲欧美日韩视频二区| 亚洲成人777| 在线观看91视频| 国产综合成人久久大片91| 日韩欧美你懂的| 欧美va天堂| 亚洲女人****多毛耸耸8| 久久国产精品久久w女人spa| 国产在线视频精品一区| 精品成a人在线观看| 欧美精品一区二区三区在线看午夜| 国产精品麻豆久久久| 国产精品一区视频| 麻豆国产91在线播放| 日韩免费看网站| 欧美黄色aaaa| 一区二区三区四区在线播放 | 欧美日韩一区在线观看视频| 一区二区理论电影在线观看| 一本到一区二区三区| 国产福利一区二区三区视频在线| 久久亚洲综合av| 99国产精品| 狠狠网亚洲精品| 国产日产欧美精品一区二区三区| 91久久亚洲| 免费观看91视频大全| 欧美tickling网站挠脚心| 亚洲午夜精品久久久久久浪潮 | 激情综合网址| 日本女人一区二区三区| 26uuu色噜噜精品一区| 亚洲高清在线播放| 麻豆精品国产91久久久久久| 2024国产精品| 国产精品美女久久久| 国产呦萝稀缺另类资源| 亚洲国产精品av| 色综合久久久网| 99精品在线观看视频| 一区二区成人在线| 在线播放中文一区| 亚洲图片欧洲图片日韩av| 老汉av免费一区二区三区| 国产欧美视频一区二区| 一本大道久久a久久综合婷婷 | 91久久人澡人人添人人爽欧美| 成人av电影在线网| 亚洲综合精品自拍| 欧美一区二区成人6969| 亚洲手机视频| 久久不见久久见免费视频1| 欧美国产精品中文字幕| 久久综合婷婷| 91丨九色丨国产丨porny| 亚洲va欧美va人人爽午夜 | 麻豆成人av在线| 中文字幕一区二区三区视频 | 亚洲国产日韩一区二区| 精品国免费一区二区三区| 亚洲综合不卡| 99视频有精品| 麻豆精品国产91久久久久久| 中文字幕一区免费在线观看| 日韩天堂在线观看| 欧美亚洲三区| 成人av电影在线观看| 日韩中文字幕1| 国产精品―色哟哟| 777奇米成人网| 国产精品资源| 91麻豆国产自产在线观看| 免费高清在线一区| 中文av一区二区| 欧美日高清视频| 宅男噜噜噜66一区二区| 成人激情视频网站| 美女精品一区二区| 亚洲人成电影网站色mp4| 日韩免费高清av| 在线精品视频免费播放| 精品动漫一区| 成人ar影院免费观看视频| 免费在线观看一区二区三区| 亚洲私人影院在线观看| 久久中文字幕电影| 欧美日韩五月天| 亚洲综合社区| 国内精品久久久久久久97牛牛| 国产**成人网毛片九色| 麻豆精品国产传媒mv男同| 亚洲综合色噜噜狠狠| 国产女人水真多18毛片18精品视频| 91精品啪在线观看国产60岁| 一本一道久久a久久精品综合蜜臀| 国产精品igao视频网网址不卡日韩| 国产美女精品在线| 男男视频亚洲欧美| 亚洲图片欧美一区| 中文字幕亚洲一区二区av在线 | 欧美午夜电影在线播放| 国产亚洲精品久久飘花| 欧美日韩一区二区三区在线视频 | 久久成人一区| 99精品国产99久久久久久福利| 91免费精品国自产拍在线不卡| 国产成人午夜精品5599 | 一区二区三区在线看| 国产亚洲欧美日韩在线一区| 日韩午夜在线观看| 欧美三电影在线| 久久精品免费| 亚洲国产精品第一区二区| 午夜精品亚洲| 91一区二区三区在线播放| 大白屁股一区二区视频| 国产精品一二三四五| 青青草伊人久久| 天天av天天翘天天综合网色鬼国产 | 欧美日韩免费| 91在线丨porny丨国产| 高清久久久久久| 国产九九视频一区二区三区| 久久精品国产久精国产| 免费看欧美女人艹b| 日韩有码一区二区三区| 偷窥少妇高潮呻吟av久久免费| 亚洲国产美女搞黄色| 一区二区三区精品视频在线| 最近日韩中文字幕| 国产精品传媒入口麻豆| 中文字幕精品在线不卡| 久久久久久久久99精品| 久久久美女艺术照精彩视频福利播放| 日韩欧美亚洲国产精品字幕久久久 | 久久精品国产精品亚洲综合| 麻豆精品一区二区三区| 秋霞影院一区二区| 蜜桃久久av一区| 久久国产精品99精品国产| 久久精品久久综合| 韩国精品久久久| 国产精品一线二线三线| 高潮精品一区videoshd| 成人久久久精品乱码一区二区三区| 国产成人av影院| av电影天堂一区二区在线观看| 97精品国产露脸对白| 欧美精品一区在线| 影音先锋一区| 国产精品久久久久久久久久直播 | 国产精品乱人伦一区二区| 亚洲欧美日韩系列| 亚洲线精品一区二区三区八戒| 亚洲国产日韩a在线播放性色| 日韩电影在线观看网站| 狠狠色丁香久久婷婷综合丁香| 国产伦精品一区二区三区在线观看|