在mysql语法中用来修改数据的命令(explain命令为什么可能会修改MySQL数据)
在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 | <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数据的资料请关注开心学习网其它相关文章!
原文链接:https://www.cnblogs.com/abclife/p/14101191.html
- mysql limit越大越慢(MySQL limit分页大偏移量慢的原因及优化方案)
- mysql添加数据很慢(mysql如何优化插入记录速度)
- mysql和utf8哪个好(为什么在MySQL中不建议使用UTF-8)
- 如何用mysql建立图书管理系统(图书管理系统的sqlserver数据库设计示例)
- mysql8.0查询操作(MySQL 8.0 redo log的深入解析)
- mysql安装详解(MySQL Router的安装部署)
- mysqlset用法(mysql descDESCRIBE命令实例讲解)
- oracle和mysql查询所有表(Oracle、MySQL和SqlServe三种数据库分页查询语句的区别介绍)
- mysql not exists用法(mysql中EXISTS和IN的使用方法比较)
- mysql的简单介绍(MySQL Shell的介绍以及安装)
- 修改mysql默认超时(MySQL sql_mode修改不生效的原因及解决)
- mysqlsource命令作用(MySQL source命令的使用简介)
- mysql insert into 怎么用(MySQL中INSERT的一般用法)
- mysql出现的问题及解决方法(mysql升级到5.7时,wordpress导数据报错1067的问题)
- 宝塔数据库不小心删了(宝塔面板MySQL数据库经常自动停止的解决方法)
- druid数据库连接池原理详解(阿里巴巴Druid,轻松实现MySQL数据库加密!)
- 九月初,爱如蜜糖,甜到心扉,迷恋彼此,一日不见兮,思之若狂(九月初爱如蜜糖)
- ()
- 对你思念入骨的女人,跟你见面时会有这几种表现,藏都藏不住(对你思念入骨的女人)
- 纳兰性德绝美作,一场重逢,成就最后一首称得上惊艳的《如梦令》(纳兰性德绝美作)
- 如何快速赚钱(如何快速赚钱方法真实有效)
- 这里输入关键词(如何输入关键词)
热门推荐
- html正确的颜色表达方式(HTML文本属性&颜色控制属性的实现)
- mysql多核cpu利用(mysql CPU高负载问题排查)
- dedecms授权查询(解析dedeCMS验证码的实现代码)
- apache虚拟域名配置(Apache虚拟主机的配置和泛域名解析实现代码)
- django url配置失效(解决Django生产环境无法加载静态文件问题的解决)
- web界面测试中需要测试的几个点
- sql server 管理日志可以删除吗(SQL Server查看login所授予的具体权限问题)
- dedecms安全设置(织梦系统DedeCMS设定栏目及文档权限登录后跳转到登陆前的页面的实现方法)
- mysqldump导入导出(MySQL官方导出工具mysqlpump的使用)
- 服务器启动nginx服务的命令(Nginx服务器添加Systemd自定义服务过程解析)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9