详解Mysql函数调用优化
来源:脚本之家
时间:2023-01-07 12:04:54 470浏览 收藏
怎么入门数据库编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《详解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()
则执行的次数更少,这可以减少不确定性对优化的影响。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。
-
483 收藏
-
326 收藏
-
268 收藏
-
177 收藏
-
130 收藏
-
475 收藏
-
266 收藏
-
273 收藏
-
283 收藏
-
210 收藏
-
371 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 斯文的羊
- 这篇技术贴真及时,好细啊,赞 👍👍,收藏了,关注作者了!希望作者能多写数据库相关的文章。
- 2023-02-05 19:05:11
-
- 幽默的芹菜
- 赞 👍👍,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢博主分享文章内容!
- 2023-02-03 18:25:32
-
- 背后的花卷
- 这篇文章太及时了,师傅加油!
- 2023-01-29 04:00:23
-
- 俊秀的保温杯
- 这篇文章真是及时雨啊,太全面了,受益颇多,mark,关注博主了!希望博主能多写数据库相关的文章。
- 2023-01-23 15:52:00
-
- 独特的胡萝卜
- 太详细了,已收藏,感谢作者大大的这篇博文,我会继续支持!
- 2023-01-16 16:38:41
-
- 善良的台灯
- 好细啊,码起来,感谢作者大大的这篇文章,我会继续支持!
- 2023-01-12 12:03:43
-
- 悦耳的小猫咪
- 这篇技术贴太及时了,楼主加油!
- 2023-01-11 06:31:52
-
- 欢呼的宝马
- 很好,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢大佬分享博文!
- 2023-01-10 19:17:26
-
- 失眠的板凳
- 太详细了,码住,感谢up主的这篇文章,我会继续支持!
- 2023-01-10 16:36:10
-
- 还单身的高跟鞋
- 这篇文章太及时了,好细啊,很好,已收藏,关注老哥了!希望老哥能多写数据库相关的文章。
- 2023-01-10 15:25:16
-
- 专一的毛衣
- 这篇博文出现的刚刚好,很详细,很有用,码起来,关注作者了!希望作者能多写数据库相关的文章。
- 2023-01-09 22:36:41
-
- 心灵美的乌冬面
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢老哥分享技术文章!
- 2023-01-08 23:17:21