前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MYSQL explain 可没有那么简单,explain的猫腻与函数

MYSQL explain 可没有那么简单,explain的猫腻与函数

作者头像
AustinDatabases
发布2021-01-14 15:06:10
8350
发布2021-01-14 15:06:10
举报
文章被收录于专栏:AustinDatabasesAustinDatabases

explain 到底会不会执行命令着一点很多人应该是不置可否的任务,他不能执行命令,而仅仅是对语句进行评估然后反馈执行的计划。

我们创建一个函数

DELIMITER

CREATE FUNCTION insertinto() RETURNS char(50) CHARSET utf8 DETERMINISTICBEGIN insert into test (id) values (1),(2);RETURN 'OK'; END

上面的例子中关于mysql 中的函数实际上是被执行了,那如果我换了成其他的DML 语句会怎样,后果不敢想象。

所以这里第一点的问题是,函数尽量不要带有和表有关的操作。如果带有和表有关的操作则在explain的情况下会出现上面的问题,想象中是查看执行计划,但结果是操作了这个语句。

那么出现这样的问题,如果要进行执行计划的查看,但是又不想不运行这个函数,可以通过在执行explain 语句的情况前添加事务的方法,来规避一些风险。

同时在MYSQL 8 中的后续命令 explain analyze 命令是否也有这个问题我们看一下,从下面的图可以看出,MYSQL 8 中新添加了的 explain ananlyze 实际上在命令的安全方面和之前没有太大的变化,所以这个安全的问题,还是需要注意。

关于MYSQL 8 中的的 explain analyze 这个命令如果感兴趣的可以查看

https://mysqlserverteam.com/mysql-explain-analyze/

这里有详细的说明和使用的方法,尤其对于树形展示的方法,便于处理和查看

这里没有提供复杂的语句,所以没有展现 explain format = tree 对于查看执行计划的有利点,有兴趣大家可以去尝试看看,这样查看执行计划对比之前是否有便利之处。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-01-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 AustinDatabases 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档