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

歡迎訪問 生活随笔!

生活随笔

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

数据库

explain mysql 权限_explain命令为什么可能会修改MySQL数据

發布時間:2025/3/20 数据库 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 explain mysql 权限_explain命令为什么可能会修改MySQL数据 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

explain命令為什么可能會修改MySQL數據,用戶,函數,數據,可能會,權限

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

易采站長站,站長之家為您整理了explain命令為什么可能會修改MySQL數據的相關內容。

如果有人問你,對查詢執行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???? | | 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數據的資料請關注易采站長站其它相關文章!以上就是關于對explain命令為什么可能會修改MySQL數據的詳細介紹。歡迎大家對explain命令為什么可能會修改MySQL數據內容提出寶貴意見

總結

以上是生活随笔為你收集整理的explain mysql 权限_explain命令为什么可能会修改MySQL数据的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 午夜免费福利在线 | 国产98在线| 久久免费视频6 | 高清视频免费在线观看 | 波多野结衣视频网址 | 丁香婷婷在线 | 日本xxxx裸体xxxx出水 | 亚洲老女人 | 国产精品久久免费 | 网站在线观看你懂的 | 一本一道波多野结衣av黑人 | k8经典成人理伦片 | 超碰婷婷| 欧美一区二区网站 | 免费久久一级欧美特大黄 | 性视频在线播放 | 91免费视频 | 欧美成人黄色片 | 91久久久久久久久久久久久 | 国产91免费观看 | 国产精品视频全国免费观看 | 国产精品美女 | 在线观看日韩一区二区 | 天堂网在线看 | 69色| 国产三级av片| 五月天婷婷伊人 | 国产性色视频 | 日韩av一二三 | 亚洲aⅴ在线观看 | 国产粉嫩呻吟一区二区三区 | 中文在线√天堂 | 青青草av在线播放 | 人人艹人人 | 色视频在线观看免费 | 自拍偷拍一区二区三区 | 国产一区二区在线视频观看 | 成人国产| 三上悠亚 在线观看 | 第一章婶婶的性事 | ass精品国模裸体pics | 国模婷婷 | 日韩青青草| 中文国产在线观看 | 人人看人人澡 | 国产综合社区 | 五月婷视频 | av导航站| 国产精品第6页 | 成人性生交大免费看 | www.玖玖玖 | 香蕉视频官网 | 亚洲国产精品电影 | 国产无遮无挡120秒 欧美综合图片 | 99热热 | 久久亚洲精品石原莉奈 | 色天堂视频 | 久久性 | 日本欧美久久久久免费播放网 | 中文字幕+乱码+中文乱码www | 国产一级二级三级精品 | 99久久99久久 | 人人爱人人 | 欧洲做受高潮免费看 | 国产一区视频在线免费观看 | 天堂资源av | 久草精品在线观看 | 国产欧美亚洲精品 | 日韩国产欧美在线视频 | 久草中文在线 | 91麻豆国产视频 | 国产成人综合欧美精品久久 | 中出在线 | 国产av无码专区亚洲av | 日韩一区在线视频 | 毛片基地免费 | 久久香蕉精品视频 | 99久久亚洲精品日本无码 | 视频福利在线 | 日本网站在线 | 色久阁| 日本高清免费不卡视频 | 极品尤物在线观看 | 韩国色网| 免费一级一片 | 日日碰狠狠添天天爽无码av | www黄色片| 丁香七月激情 | 欧美一区二区三区色 | 男女猛烈无遮挡免费视频 | 中文字幕第十一页 | 国产普通话bbwbbwbbw | 91chinese在线| 欧美成人一区在线观看 | 草草影院欧美 | 99精品偷自拍 | 亚洲熟悉妇女xxx妇女av | 中文字幕有码av | 国产绿帽刺激高潮对白 |