2025年窗口函数 max(窗口函数 mysql)

窗口函数 max(窗口函数 mysql)h4 data id heading 0 函数调用优化 h4 MySQL 函数在内部被标记为确定性或不确定性 如果给定参数固定值的函数可以为不同的调用返回不同的结果 则它是不确定的 不确定函数的示例 如果某个函数被标记为不确定的 则将针对每一行 从一个表中选择时 或行的组合 从多表联接中选择时 评估子句中对该函数的引用

大家好,我是讯享网,很高兴认识大家。



 <h4 data-id="heading-0">函数调用优化</h4> 

讯享网

MySQL函数在内部被标记为确定性或不确定性。如果给定参数固定值的函数可以为不同的调用返回不同的结果,则它是不确定的。不确定函数的示例: , 。

如果某个函数被标记为不确定的,则将针对每一行(从一个表中选择时)或行的组合(从多表联接中选择时)评估子句中对该函数的引用。

MySQL还根据参数的类型(参数是表列还是常量值)确定何时评估函数。每当表列更改值时,都必须评估将表列作为参数的确定性函数。

非确定性函数可能会影响查询性能。例如,某些优化可能不可用,或者可能需要更多锁定。以下讨论使用 但也适用于其他不确定性函数。

假设一个表具有以下定义:

讯享网

考虑以下两个查询:

 

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

  • 第一个查询始终最多产生一行,因为带有常量参数的常量是一个常量值,并用于索引查找。
  • 第二个查询包含一个使用非确定性函数的表达式,该表达式 在查询中不是常量,但实际上对表的每一行都有一个新值。因此,查询读取表的每一行,评估每一行的谓词,并输出主键与随机值匹配的所有行。根据列值和序列中的值, 它可以是零行,一行或多行 。

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


讯享网

讯享网

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

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

  • 由于不确定函数不会产生恒定值,因此优化器无法使用其他可能适用的策略,例如索引查找。结果可能是表扫描。
  • 可能升级为范围键锁,而不是为一个匹配的行获取单行锁。
  • 无法确定执行的更新对于复制是不安全的。

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

  • 将包含不确定性函数的表达式移到单独的语句,将值保存在变量中。在原始语句中,将表达式替换为对变量的引用,优化器可以将该变量视为常量值:
     
  • 将随机值分配给派生表中的变量。此技术使变量在子句中的比较中使用之前被分配一个值 :
    讯享网

如前所述,该子句中的不确定性表达式 可能会阻止优化并导致表扫描。但是,如果其他表达式是确定性的,则可以部分优化该子句。例如:

 

如果优化器可以用来减少所选行的集合, 则执行的次数更少,这可以减少不确定性对优化的影响。

更多内容欢迎关注我的个人公众号“韩哥有话说”,100G人工智能学习资料,大量后端学习资料等你来拿。

讯享网 <br> 

小讯
上一篇 2025-06-03 13:08
下一篇 2025-04-24 15:41

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/186680.html