详解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 函数调用优化的资料请关注真格学网其它相关文章!

您可能感兴趣的文章:Zend studio for eclipse中使php可以调用mysql相关函数的设置方法MySQL 函数索引的优化方案MySQL中聚合函数count的使用和性能优化技巧MySQL利用procedure analyse()函数优化表结构

  • 本文相关:
  • mysql中engine=innodb和engine=myisam的区别介绍
  • php学习之sql语句快速入门
  • mysql问题之slow log中出现大量的binlog dump记录的解决方法
  • 详解如何使用dockerhub官方的mysql镜像
  • mysql数据库设计之利用python操作schema方法详解
  • mysql 随机密码生成代码
  • mysql通过文档读取并执行命令之快速为mysql添加多用户和数据库技
  • mysql日期加减函数详解
  • mysql字符串索引更合理的创建规则讨论
  • mysql group by对单字分组序和多字段分组的方法讲解
  • 在mysql里怎样自定义函数,如何调用和执行
  • 在mysql中自定义的函数怎么调用
  • 怎么代替mysql的in函数优化速度
  • mysql 优化sql方法有哪些
  • PHP 函数执行mysql的效率问题
  • mysql存储过程怎么调用自定义的函数
  • navicat里面怎么执行mysql函数
  • c#如何调用mysql的函数
  • mysql自定义函数里可以调用函数吗
  • 用Mybatis框架怎么调用MySQL的函数
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页zend studio for eclipse中使php可以调用mysql相关函数的设置方法mysql 函数索引的优化方案mysql中聚合函数count的使用和性能优化技巧mysql利用procedure analyse()函数优化表结构mysql中engine=innodb和engine=myisam的区别介绍php学习之sql语句快速入门mysql问题之slow log中出现大量的binlog dump记录的解决方法详解如何使用dockerhub官方的mysql镜像mysql数据库设计之利用python操作schema方法详解mysql 随机密码生成代码mysql通过文档读取并执行命令之快速为mysql添加多用户和数据库技mysql日期加减函数详解mysql字符串索引更合理的创建规则讨论mysql group by对单字分组序和多字段分组的方法讲解mysql安装图解 mysql图文安装教程can""""t connect to mysql servwindows下mysql5.6版本安装及配置mysql字符串截取函数substring的mysql创建用户与授权方法mysql提示:the server quit withmysql——修改root密码的4种方法mysql日期数据类型、时间类型使用mysql之timestamp(时间戳)用法mysql update语句的用法详解mysql主从复制配置过程mysql定时备份之使用linux下的crontab定时mysql入门(四) 数据表的数据插入、更新、mysql仿asp的数据库操作类通过命令行导入到mysql数据库时出现乱码的mysql数据库防止人为误操作的实例讲解mysql降权运行之mysql以guests帐户启动设linux下安装mysql8.0.11的教程浅谈mysql使用limit分页优化方案的实现mysql存储过程原理与使用方法详解
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved