电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

explain命令為什么可能會(huì)修改MySQL數(shù)據(jù)

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

如果有人問(wèn)你,對(duì)查詢執(zhí)行EXPLAIN是否可以改變你的數(shù)據(jù)庫(kù),你可能會(huì)說(shuō)不會(huì); 通常都是這么認(rèn)為的。EXPLAIN應(yīng)該向我們展示查詢是如何執(zhí)行的,而不是執(zhí)行查詢,因此它不能更改任何數(shù)據(jù)。

不幸的是,在這種情況下,常識(shí)并不適用于MySQL(在寫這篇文章的時(shí)候,MySQL 8.0.21和以前的版本)-有一些情況下,explain可以改變你的數(shù)據(jù)庫(kù),就像這個(gè)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>

這里的問(wèn)題是explain執(zhí)行了存儲(chǔ)函數(shù)cleanup(),該函數(shù)是可以修改數(shù)據(jù)的。

這與更理智的PostgreSQL行為不同,后者在運(yùn)行EXPLAIN時(shí)不會(huì)執(zhí)行存儲(chǔ)函數(shù)(如果你運(yùn)行EXPLAIN ANALYZE,則會(huì)執(zhí)行)。

在MySQL中,這個(gè)決定來(lái)自于嘗試做正確的事情并提供最可靠的解釋(查詢執(zhí)行計(jì)劃很可能取決于存儲(chǔ)函數(shù)返回什么),但似乎沒(méi)有考慮這種安全權(quán)衡。

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

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

這會(huì)運(yùn)行一個(gè)多小時(shí)。

雖然很不幸有這樣的行為,但只有在擁有不受限制的權(quán)限時(shí)才會(huì)發(fā)生。如果有一個(gè)更復(fù)雜的設(shè)置,行為可能會(huì)有所不同。

如果用戶缺少EXECUTE權(quán)限,EXPLAIN語(yǔ)句將失敗。

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

如果用戶有EXECUTE權(quán)限,但是執(zhí)行存儲(chǔ)函數(shù)的用戶沒(méi)有DELETE權(quán)限,也會(huì)失敗:

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

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

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

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

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

雖然這些變通辦法可以使工具更安全地運(yùn)行EXPLAIN,但它不能幫助用戶直接運(yùn)行EXPLAIN,并且我真的希望通過(guò)重新設(shè)計(jì)EXPLAIN來(lái)解決此問(wèn)題,就像PostgreSQL那樣不會(huì)嘗試運(yùn)行存儲(chǔ)函數(shù)。對(duì)于那些想知道如何精確執(zhí)行查詢的人,現(xiàn)在有了EXPLAIN ANALYZE。

以上就是explain命令為什么可能會(huì)修改MySQL數(shù)據(jù)的詳細(xì)內(nèi)容,更多關(guān)于explain命令修改MySQL數(shù)據(jù)的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 药品仓库用除湿机-变电站用防爆空调-油漆房用防爆空调-杭州特奥环保科技有限公司 | Magnescale探规,Magnescale磁栅尺,Magnescale传感器,Magnescale测厚仪,Mitutoyo光栅尺,笔式位移传感器-苏州连达精密量仪有限公司 | 升降机-高空作业车租赁-蜘蛛车-曲臂式伸缩臂剪叉式液压升降平台-脚手架-【普雷斯特公司厂家】 | 东莞市天进机械有限公司-钉箱机-粘箱机-糊箱机-打钉机认准东莞天进机械-厂家直供更放心! | 洛阳永磁工业大吊扇研发生产-工厂通风降温解决方案提供商-中实洛阳环境科技有限公司 | 砂石生产线_石料生产线设备_制砂生产线设备价格_生产厂家-河南中誉鼎力智能装备有限公司 | 扬尘在线监测系统_工地噪声扬尘检测仪_扬尘监测系统_贝塔射线扬尘监测设备「风途物联网科技」 | 木材烘干机,木炭烘干机,纸管/佛香烘干设备-河南蓝天机械制造有限公司 | 嘉兴泰东园林景观工程有限公司_花箱护栏 | 间苯二酚,间苯二酚厂家-淄博双和化工 | 济宁工业提升门|济宁电动防火门|济宁快速堆积门-济宁市统一电动门有限公司 | PAS糖原染色-CBA流式多因子-明胶酶谱MMP-上海研谨生物科技有限公司 | 铁艺,仿竹,竹节,护栏,围栏,篱笆,栅栏,栏杆,护栏网,网围栏,厂家 - 河北稳重金属丝网制品有限公司 山东太阳能路灯厂家-庭院灯生产厂家-济南晟启灯饰有限公司 | 新疆十佳旅行社_新疆旅游报价_新疆自驾跟团游-新疆中西部国际旅行社 | 焊接烟尘净化器__焊烟除尘设备_打磨工作台_喷漆废气治理设备 -催化燃烧设备 _天津路博蓝天环保科技有限公司 | 盘扣式脚手架-附着式升降脚手架-移动脚手架,专ye承包服务商 - 苏州安踏脚手架工程有限公司 | 「钾冰晶石」氟铝酸钾_冰晶石_氟铝酸钠「价格用途」-亚铝氟化物厂家 | 企业彩铃制作_移动、联通、电信集团彩铃上传开通_彩铃定制_商务彩铃管理平台-集团彩铃网 | 心得体会网_心得体会格式范文模板| 石家庄网站建设|石家庄网站制作|石家庄小程序开发|石家庄微信开发|网站建设公司|网站制作公司|微信小程序开发|手机APP开发|软件开发 | 高温高压釜(氢化反应釜)百科 | 南京欧陆电气股份有限公司-风力发电机官网 | 焦作网 WWW.JZRB.COM| 喷播机厂家_二手喷播机租赁_水泥浆洒布机-河南青山绿水机电设备有限公司 | 天津拓展_天津团建_天津趣味运动会_天津活动策划公司-天津华天拓展培训中心 | 编织人生 - 权威手工编织网站,编织爱好者学习毛衣编织的门户网站,织毛衣就上编织人生网-编织人生 | 科威信洗净科技,碳氢清洗机,超声波清洗机,真空碳氢清洗机 | 希望影视-高清影视vip热播电影电视剧免费在线抢先看 | 基本型顶空进样器-全自动热脱附解吸仪价格-AutoHS全模式-成都科林分析技术有限公司 | 机器视觉检测系统-视觉检测系统-机器视觉系统-ccd检测系统-视觉控制器-视控一体机 -海克易邦 | 动库网动库商城-体育用品专卖店:羽毛球,乒乓球拍,网球,户外装备,运动鞋,运动包,运动服饰专卖店-正品运动品网上商城动库商城网 - 动库商城 | 防爆暖风机_防爆电暖器_防爆电暖风机_防爆电热油汀_南阳市中通智能科技集团有限公司 | 国际金融网_每日财经新资讯网 | 消防泵-XBD单级卧式/立式消防泵-上海塑泉泵阀(集团)有限公司 | 上海佳武自动化科技有限公司| 招商帮-一站式网络营销服务|互联网整合营销|网络推广代运营|信息流推广|招商帮企业招商好帮手|搜索营销推广|短视视频营销推广 | 华东师范大学在职研究生招生网_在职研究生招生联展网 | 深圳富泰鑫五金_五金冲压件加工_五金配件加工_精密零件加工厂 | 电镀标牌_电铸标牌_金属标贴_不锈钢标牌厂家_深圳市宝利丰精密科技有限公司 | 美甲贴片-指甲贴片-穿戴美甲-假指甲厂家--薇丝黛拉 | 根系分析仪,大米外观品质检测仪,考种仪,藻类鉴定计数仪,叶面积仪,菌落计数仪,抑菌圈测量仪,抗生素效价测定仪,植物表型仪,冠层分析仪-杭州万深检测仪器网 |