欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql優(yōu)化神器(推薦)

 更新時(shí)間:2020年12月21日 09:47:05   作者:Sunshine-松  
這篇文章主要介紹了Mysql優(yōu)化神器(推薦),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

今天逛github時(shí),發(fā)現(xiàn)了這款對 SQL 進(jìn)行優(yōu)化和改寫的自動化工具sora。感覺挺不錯的,就下載學(xué)習(xí)了一下。這個(gè)工具支持的功能比較多,可以作為我們?nèi)粘i_發(fā)中的一款輔助工具,現(xiàn)在我就把它推薦給你們~~~

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

背景

在我們?nèi)粘i_發(fā)中,優(yōu)化SQL總是我們?nèi)粘i_發(fā)任務(wù)之一。例行 SQL 優(yōu)化,不僅可以提升程序性能,還能夠降低線上故障的概率。

目前常用的 SQL 優(yōu)化方式包括但不限于:業(yè)務(wù)層優(yōu)化、SQL邏輯優(yōu)化、索引優(yōu)化等。其中索引優(yōu)化通常通過調(diào)整索引或新增索引從而達(dá)到 SQL 優(yōu)化的目的。索引優(yōu)化往往可以在短時(shí)間內(nèi)產(chǎn)生非常巨大的效果。如果能夠?qū)⑺饕齼?yōu)化轉(zhuǎn)化成工具化、標(biāo)準(zhǔn)化的流程,減少人工介入的工作量,無疑會大大提高我們的工作效率。

SOAR(SQL Optimizer And Rewriter) 是一個(gè)對 SQL 進(jìn)行優(yōu)化和改寫的自動化工具。由小米人工智能與云平臺的數(shù)據(jù)庫團(tuán)隊(duì)開發(fā)與維護(hù)。

與業(yè)內(nèi)其他優(yōu)秀產(chǎn)品對比如下:

SOAR sqlcheck pt-query-advisor SQL Advisor Inception sqlautoreview
啟發(fā)式建議 ✔️ ✔️ ✔️ ✔️ ✔️
索引建議 ✔️ ✔️ ✔️
查詢重寫 ✔️
執(zhí)行計(jì)劃展示 ✔️
Profiling ✔️
Trace ✔️
SQL在線執(zhí)行 ✔️
數(shù)據(jù)備份 ✔️

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

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

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

安裝

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

下載二進(jìn)制安裝包

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

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

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

測試一下:

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

源碼安裝

依賴環(huán)境:

1. Go 1.10+
2. git

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

  • mysql 客戶端版本需要與容器中MySQL版本相同,避免出現(xiàn)由于認(rèn)證原因?qū)е聼o法連接問題
  • docker MySQL Server測試容器管理
  • govendor Go包管理
  • retool 依賴外部代碼質(zhì)量靜態(tài)檢查工具二進(jìn)制文件管理

生成二進(jìn)制文件:

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

簡單使用

0. 前置準(zhǔn)備

準(zhǔn)備一個(gè)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語句(不運(yùn)行)

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

現(xiàn)在是完全根據(jù)SQL語句進(jìn)行分析的,因?yàn)闆]有連接到mysql??梢钥吹?,給出的報(bào)告也很詳細(xì),但是只是空殼子,僅憑SQL語句給出的分析并不是準(zhǔn)確的,所以我們開始接下來的應(yīng)用。

2. 連接mysql生成EXPLAIN分析報(bào)告

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

vi soar.yaml
# yaml format config file
online-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

配置好了,我們來實(shí)踐一下子吧:

$ 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分
 
```sql
SELECT
 id, username, nickname, PASSWORD, salt, avatar, uptime
FROM
 users
WHERE
 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用于使用常數(shù)值比較PRIMARY KEY時(shí), 當(dāng)查詢的表僅有一行時(shí), 使用system. 例:SELECT * FROM tbl WHERE col = 1.

這回結(jié)果中多了EXPLAIN信息分析報(bào)告。這對于剛開始入門的小伙伴們是友好的,因?yàn)槲覀儗xplain解析的字段并不熟悉,有了它我們可以完美的分析SQL中的問題,是不是很棒。

3. 語法檢查

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

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

這里select關(guān)鍵字少了一個(gè)t,運(yùn)行該指令幫助我們一下就定位了問題,當(dāng)我們的sql語句很長時(shí),就可以使用該指令來輔助我們檢查SQL語句是否正確。

4. SQL美化

我們?nèi)粘i_發(fā)時(shí),經(jīng)常會看其他人寫的代碼,因?yàn)樗讲灰粯?,所以有些SQL語句會寫的很亂,所以這個(gè)工具就派上用場了,我們可以把我們的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, uptime
FROM
 users
WHERE
 username = 'asong1111';

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

結(jié)尾

因?yàn)槲乙膊攀莿偸褂眠@個(gè)工具,更多的玩法我還沒有發(fā)現(xiàn),以后補(bǔ)充。更多玩法可以自己研究一下,github傳送門:https://github.com/XiaoMi/soar。官方文檔其實(shí)很粗糙,更多方法解鎖還要靠自己研究,畢竟源碼已經(jīng)給我們了,對于學(xué)習(xí)go也有一定幫助,當(dāng)作一個(gè)小項(xiàng)目慢慢優(yōu)化豈不是更好呢~~。

到此這篇關(guān)于Mysql優(yōu)化神器(推薦)的文章就介紹到這了,更多相關(guān)Mysql優(yōu)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MYSQL 淺談MyISAM 存儲引擎

    MYSQL 淺談MyISAM 存儲引擎

    mysql中用的最多存儲引擎就是innodb和myisam。做為Mysql的默認(rèn)存儲引擎,myisam值得我們學(xué)習(xí)一下,以下是我對《高性能MYSQL》書中提到的myisam的理解,請大家多多指教
    2012-04-04
  • Mysql BinLog存儲機(jī)制與數(shù)據(jù)恢復(fù)方式

    Mysql BinLog存儲機(jī)制與數(shù)據(jù)恢復(fù)方式

    這篇文章主要介紹了Mysql BinLog存儲機(jī)制與數(shù)據(jù)恢復(fù)方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • 為什么MySQL查詢速度會慢

    為什么MySQL查詢速度會慢

    這篇文章主要介紹了為什么MySQL查詢速度會慢的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • MySQL 數(shù)據(jù)恢復(fù)的多種方法匯總

    MySQL 數(shù)據(jù)恢復(fù)的多種方法匯總

    日常工作中,總會有因手抖、寫錯條件、寫錯表名、錯連生產(chǎn)庫造成的誤刪庫表和數(shù)據(jù)的事情發(fā)生。但是,如果每次刪庫都跑路的話,怕是再也不好找工作了吧!所以,刪庫跑路不是上上策
    2021-06-06
  • mysql 5.7.18 winx64安裝配置方法圖文教程

    mysql 5.7.18 winx64安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了windows7下mysql 5.7.18 winx64安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • Suse Linux 10中MySql安裝與配置步驟

    Suse Linux 10中MySql安裝與配置步驟

    這篇文章主要介紹了Suse Linux 10中MySql安裝與配置步驟,本文詳細(xì)的講解了安裝步驟,需要的朋友可以參考下
    2015-05-05
  • mysql的select?into給多個(gè)字段變量賦值方式

    mysql的select?into給多個(gè)字段變量賦值方式

    這篇文章主要介紹了mysql的select?into給多個(gè)字段變量賦值方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • mysql設(shè)置某字段不能重復(fù)問題

    mysql設(shè)置某字段不能重復(fù)問題

    這篇文章主要介紹了mysql設(shè)置某字段不能重復(fù)問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • MySql開發(fā)之自動同步表結(jié)構(gòu)

    MySql開發(fā)之自動同步表結(jié)構(gòu)

    這篇文章主要給大家介紹了關(guān)于MySql開發(fā)之自動同步表結(jié)構(gòu)的相關(guān)資料,這樣可以避免在開發(fā)中由于修改數(shù)據(jù)庫字段導(dǎo)致的數(shù)據(jù)庫表不一致問題,需要的朋友可以參考下
    2021-05-05
  • MySQL prepare原理詳解

    MySQL prepare原理詳解

    這篇文章主要介紹了MySQL prepare的相關(guān)內(nèi)容,包括prepare的產(chǎn)生,在服務(wù)器端的執(zhí)行過程,以及jdbc對prepare的處理以及相關(guān)測試,需要的朋友可以了解下。希望對大家有所幫助。
    2017-09-09

最新評論