亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

explain命令為什么可能會修改MySQL數據

瀏覽:50日期:2023-10-07 17:21:36

如果有人問你,對查詢執行EXPLAIN是否可以改變你的數據庫,你可能會說不會; 通常都是這么認為的。EXPLAIN應該向我們展示查詢是如何執行的,而不是執行查詢,因此它不能更改任何數據。

不幸的是,在這種情況下,常識并不適用于MySQL(在寫這篇文章的時候,MySQL 8.0.21和以前的版本)-有一些情況下,explain可以改變你的數據庫,就像這個Bug所示:

mysql> select version();+-----------+| version() |+-----------+| 5.7.31 |+-----------+1 row in set (0.01 sec) mysql> DELIMITER $$mysql> CREATE FUNCTION `cleanup`() RETURNS char(50) CHARSET utf8mb4 -> DETERMINISTIC -> BEGIN -> delete from test.t1; -> RETURN ’OK’; -> END $$Query OK, 0 rows affected (0.00 sec) mysql>

mysql> select * from t1$$+------+------+| id | name |+------+------+| 1 | aa || 2 | bb |+------+------+2 rows in set (0.00 sec) mysql> explain select * from (select cleanup()) as t1clean$$+----+-------------+------------+------------+--------+---------------+------+---------+------+------+----------+----------------+| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |+----+-------------+------------+------------+--------+---------------+------+---------+------+------+----------+----------------+| 1 | PRIMARY | <derived2> | NULL | system | NULL | NULL | NULL | NULL | 1 | 100.00 | NULL || 2 | DERIVED | NULL | NULL | NULL | NULL | NULL | NULL | NULL | NULL | NULL | No tables used |+----+-------------+------------+------------+--------+---------------+------+---------+------+------+----------+----------------+2 rows in set, 1 warning (0.01 sec) mysql> select * from t1$$Empty set (0.00 sec) mysql>

這里的問題是explain執行了存儲函數cleanup(),該函數是可以修改數據的。

這與更理智的PostgreSQL行為不同,后者在運行EXPLAIN時不會執行存儲函數(如果你運行EXPLAIN ANALYZE,則會執行)。

在MySQL中,這個決定來自于嘗試做正確的事情并提供最可靠的解釋(查詢執行計劃很可能取決于存儲函數返回什么),但似乎沒有考慮這種安全權衡。

盡管當前MySQL EXPLAIN設計的這種后果是最嚴重的后果之一,但你還遇到一個問題,即EXPLAIN(理性的用戶希望這是檢查查詢性能的一種快速方法)可能需要花費大量時間才能完成, 例如:

mysql> explain select * from (select sleep(5000) as a) b;

這會運行一個多小時。

雖然很不幸有這樣的行為,但只有在擁有不受限制的權限時才會發生。如果有一個更復雜的設置,行為可能會有所不同。

如果用戶缺少EXECUTE權限,EXPLAIN語句將失敗。

mysql> explain select * from (select cleanup()) as t1clean;ERROR 1370 (42000): execute command denied to user ’abce’@’localhost’ for routine ’test.cleanup’

如果用戶有EXECUTE權限,但是執行存儲函數的用戶沒有DELETE權限,也會失敗:

mysql> explain select * from (select cleanup()) as t1clean;ERROR 1142 (42000): DELETE command denied to user ’abce’@’localhost’ for table ’t1’

那么,如果想提高EXPLAIN的安全性,例如,正在開發Percona Monitoring and Management之類的工具,該工具除其他功能之外,還允許用戶對其查詢運行EXPLAIN,該怎么辦?

·建議用戶設置權限以進行正確的監控。這應該是這個(以及許多其他)問題的第一道防線,但是,這很難依靠。許多用戶將選擇簡單的方式,并將使用具有完全特權的“ root”用戶進行監控。

·將EXPLAIN語句包裝在BEGIN…ROLLBACK中,這將撤消EXPLAIN可能造成的任何損害。缺點當然是刪除數據的“工作”,并且在撤消工作時將完成工作。(注意:當然,這僅適用于事務表。如果你仍然運行MyISAM,在這種情況下,有更嚴重的問題需要擔心)

·使用“set transaction read-only”,表示不希望進行任何寫操作。在這種情況下,嘗試寫數據的EXPLAIN將失敗,并且不做任何工作。

雖然這些變通辦法可以使工具更安全地運行EXPLAIN,但它不能幫助用戶直接運行EXPLAIN,并且我真的希望通過重新設計EXPLAIN來解決此問題,就像PostgreSQL那樣不會嘗試運行存儲函數。對于那些想知道如何精確執行查詢的人,現在有了EXPLAIN ANALYZE。

以上就是explain命令為什么可能會修改MySQL數據的詳細內容,更多關于explain命令修改MySQL數據的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 九九51精品国产免费看 | 狠狠色综合久久婷婷 | 欧美日韩视频一区二区 | 久久国内免费视频 | 日批网站在线观看 | 口国产成人高清在线播放 | 夜鲁鲁鲁夜夜综合视频欧美 | 免费国产在线观看不卡 | 久久这里只有精品免费播放 | 国产亚洲美女精品久久久久 | 国产成在线观看免费视频成本人 | 亚洲国产情侣一区二区三区 | 麻豆传媒网站网址入口 | 成人黄色三级视频 | 久久福利一区 | 簧片在线免费看 | 欧美三级成人 | 一级毛片一级毛片一级级毛片 | 免费黄色片大全 | 99在线观看国产 | 伊人久久亚洲综合 | 黄色福利片 | 久久久香蕉视频 | 亚洲精品国产专区91在线 | 2020国产成人精品免费视频 | 狠狠色香婷婷久久亚洲精品 | 黄网站免费看 | 伊人色综合久久天天伊 | 久综合色| 成人黄色视屏 | 九九精品视频在线免费观看 | 久草播放器 | 国产免费a v吧在线观看不卡 | 日韩在线视频线视频免费网站 | 成人性生免费视频 | 久操香蕉 | 免费成人福利视频 | 国产成人99精品免费观看 | 亚洲国产中文字幕 | 国产老头老太性视频 | 国产毛片一区二区 |