mysql优化使用方法(详解Mysql函数调用优化)
mysql优化使用方法
详解Mysql函数调用优化函数调用优化
MySQL函数在内部被标记为确定性或不确定性。如果给定参数固定值的函数可以为不同的调用返回不同的结果,则它是不确定的。不确定函数的示例: RAND()
, UUID()
。
如果某个函数被标记为不确定的,则将WHERE
针对每一行(从一个表中选择时)或行的组合(从多表联接中选择时)评估子句中对该函数的引用。
MySQL还根据参数的类型(参数是表列还是常量值)确定何时评估函数。每当表列更改值时,都必须评估将表列作为参数的确定性函数。
非确定性函数可能会影响查询性能。例如,某些优化可能不可用,或者可能需要更多锁定。以下讨论使用 RAND()
但也适用于其他不确定性函数。
假设一个表t具有以下定义:
|
CREATE TABLE t (id INT NOT NULL PRIMARY KEY , col_a VARCHAR (100)); |
考虑以下两个查询:
|
SELECT * FROM t WHERE id = POW(1,2); SELECT * FROM t WHERE id = FLOOR(1 + RAND() * 49); |
由于与主键的相等性比较,两个查询似乎都使用了主键查找,但这仅适用于第一个查询:
-
第一个查询始终最多产生一行,因为
POW()
带有常量参数的常量是一个常量值,并用于索引查找。 -
第二个查询包含一个使用非确定性函数的表达式,该表达式
RAND()
在查询中不是常量,但实际上对表的每一行都有一个新值t。因此,查询读取表的每一行,评估每一行的谓词,并输出主键与随机值匹配的所有行。根据id列值和RAND()序列中的值, 它可以是零行,一行或多行 。
非确定性的影响不仅限于 SELECT
陈述。该 UPDATE
语句使用非确定性函数来选择要修改的行:
|
UPDATE t SET col_a = some_expr WHERE id = FLOOR(1 + RAND() * 49); |
大概目的是最多更新主键与表达式匹配的一行。但是,它可能会更新零,一或多个行,具体取决于 id
列值和RAND()
序列中的值 。
刚刚描述的行为对性能和复制有影响:
- 由于不确定函数不会产生恒定值,因此优化器无法使用其他可能适用的策略,例如索引查找。结果可能是表扫描。
-
InnoDB
可能升级为范围键锁,而不是为一个匹配的行获取单行锁。 - 无法确定执行的更新对于复制是不安全的。
困难源于RAND()
对表的每一行都对函数进行一次评估的事实 。为了避免进行多功能评估,请使用以下技术之一:
- 将包含不确定性函数的表达式移到单独的语句,将值保存在变量中。在原始语句中,将表达式替换为对变量的引用,优化器可以将该变量视为常量值:
|
SET @keyval = FLOOR(1 + RAND() * 49); UPDATE t SET col_a = some_expr WHERE id = @keyval; |
-
将随机值分配给派生表中的变量。此技术使变量在
WHERE
子句中的比较中使用之前被分配一个值 :
|
SET optimizer_switch = 'derived_merge=off' ; UPDATE t, ( SELECT @keyval := FLOOR(1 + RAND() * 49)) AS dt SET col_a = some_expr WHERE id = @keyval; |
如前所述,该WHERE
子句中的不确定性表达式 可能会阻止优化并导致表扫描。但是,WHERE
如果其他表达式是确定性的,则可以部分优化该子句。例如:
|
SELECT * FROM t WHERE partial_key=5 AND some_column=RAND(); |
如果优化器可以partial_key
用来减少所选行的集合, RAND()
则执行的次数更少,这可以减少不确定性对优化的影响。
以上就是详解Mysql 函数调用优化的详细内容,更多关于Mysql 函数调用优化的资料请关注开心学习网其它相关文章!
原文链接:https://juejin.cn/post/6945659999288819726
- mysql怎么解决幻读问题(详解MySQL幻读及如何消除)
- mysql行级锁使用教程(浅析MySQL的lru链表)
- 对mysql性能优化的看法(聊聊MySQL的COUNT的性能,看看怎么最快?)
- phpmysql怎么搭建(PHP使用PDO、mysqli扩展实现与数据库交互操作详解)
- mysql效率查询(MySQL 如何分析查询性能)
- mysqltimestamp如何比较(为什么MySQL 使用timestamp可以无视时区问题.)
- mysql数据库迁移命令(MySQL数据迁移相关总结)
- ubuntu下mysql安装教程(Ubuntu 20.04 安装和配置MySql5.7的详细教程)
- mysql的浮点数类型(浅谈MySQL中float、double、decimal三个浮点类型的区别与总结)
- php考试复习题(php+mysql开发的最简单在线题库在线做题系统完整案例)
- mysql update 多个字段(mysql update case 更新字段值不固定的操作)
- mysql查询逗号分割字符串(MySQL 字符串拆分实例无分隔符的字符串截取)
- mysql实现数据的备份的命令(Windows下MySQL定时备份脚本的实现)
- docker 增大mysql连接数(docker中修改mysql最大连接数及配置文件的实现)
- mysql数据库怎么换行(MySQL数据中很多换行符和回车符的解决方法)
- mysql判断表中字段是否存在(mysql插入前判断数据是否存在的操作)
- 15帅气男士发型,清爽时尚很有型,喜欢就试试(清爽时尚很有型)
- 哪几个历史人物被影协主席李雪健演的活灵活现(哪几个历史人物被影协主席李雪健演的活灵活现)
- 王伦狭隘,晁盖霸道,宋江奸诈骨头软,只有鲁智深才适合当寨主(王伦狭隘晁盖霸道)
- 他是梁山最早的头目,江湖人称 旱地忽律 ,宋江几乎将其遗忘(他是梁山最早的头目)
- 梁山创始人杜迁,为何不受宋江待见,只排名83位(梁山创始人杜迁)
- 法国面包(法国面包法棍)
热门推荐
- mvc JavaScriptResult的用法
- html5弹出输入框下拉菜单(HTML5输入框下拉菜单功能的示例代码)
- apache 代理服务器返回403(Apache中301重定向的配置代码)
- laravel 权限管理(修改Laravel自带的认证系统的User类的命名空间的步骤)
- vue如何获取元素(vue第一次获取不到元素的解决方法记录)
- sql server中check约束
- jquery中prop和attr的区别
- python解析csv文件存到数据库(python读取csv和txt数据转换成向量的实例)
- python语言提供的3种基本数据类型(详解Python3 基本数据类型)
- mysql数据库数据分析(详解MySQL数据库千万级数据查询和存储)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9