• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    详解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);
    

    由于与主键的相等性比较,两个查询似乎都使用了主键查找,但这仅适用于第一个查询:

    非确定性的影响不仅限于 SELECT陈述。该 UPDATE语句使用非确定性函数来选择要修改的行:

    UPDATE t SET col_a = some_expr WHERE id = FLOOR(1 + RAND() * 49);
    

    大概目的是最多更新主键与表达式匹配的一行。但是,它可能会更新零,一或多个行,具体取决于 id列值和RAND()序列中的值 。

    刚刚描述的行为对性能和复制有影响:

    困难源于RAND()对表的每一行都对函数进行一次评估的事实 。为了避免进行多功能评估,请使用以下技术之一:

    SET @keyval = FLOOR(1 + RAND() * 49);
    UPDATE t SET col_a = some_expr WHERE id = @keyval;
    
    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 函数调用优化的资料请关注脚本之家其它相关文章!

    您可能感兴趣的文章:
    • MySQL空间数据存储及函数
    • MySQL中日期型单行函数代码详解
    • MySql关于null的函数使用分享
    • Mysql基础之常见函数
    • MySQL中sum函数使用的实例教程
    • MySQL处理JSON常见函数的使用
    • MySQL DATE_ADD和ADDDATE函数实现向日期添加指定时间间隔
    • 浅谈MySQL函数
    上一篇:MySql主从复制机制全面解析
    下一篇:MySQL复制问题的三个参数分析
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    详解Mysql函数调用优化 详解,Mysql,函数,调用,优化,