返回顶部
首页 > 资讯 > 数据库 >详解Mysql函数调用优化
  • 559
分享到

详解Mysql函数调用优化

2024-04-02 19:04:59 559人浏览 泡泡鱼
摘要

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

函数调用优化

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 函数调用优化的资料请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: 详解Mysql函数调用优化

本文链接: https://lsjlt.com/news/122930.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 详解Mysql 函数调用优化
    函数调用优化 MySQL函数在内部被标记为确定性或不确定性。如果给定参数固定值的函数可以为不同的调用返回不同的结果,则它是不确定的。不确定函数的示例: RAND(), UUID()。 如果某个函数被标记为不确定的,...
    99+
    2022-05-19
    MySQL 函数 MySQL 函数调用优化
  • 详解Mysql函数调用优化
    目录函数调用优化函数调用优化 MySQL函数在内部被标记为确定性或不确定性。如果给定参数固定值的函数可以为不同的调用返回不同的结果,则它是不确定的。不确定函数的示例: RAND()...
    99+
    2024-04-02
  • C++ 函数优化详解:如何优化调用栈?
    调用栈是函数调用的堆栈式记录,影响性能的主要因素包括上下文切换开销、栈溢出风险和缓存不命中。优化调用栈的技术包括减少调用深度、使用尾递归优化、使用内联函数、使用局部变量和使用智能指针。 ...
    99+
    2024-05-02
    c++ 函数优化
  • golang函数调用的优化技巧
    go 函数调用优化技巧答案:通过优化函数调用技术,可显著提高 go 程序性能。减少函数调用次数: 减少不必要的调用次数,使用位运算替代函数调用。内联函数: 将函数体嵌入调用函数,避免函数...
    99+
    2024-04-29
    函数调用优化 golang 作用域
  • C++ 函数优化详解:如何优化元编程?
    元编程优化技巧:减少计算次数,避免不必要的计算。利用 sfinae 根据代码有效性进行选择,仅生成必要的代码。内联函数和类,消除函数调用开销。使用编译时 if constexprif 根...
    99+
    2024-05-04
    c++ 函数优化
  • C++ 函数优化详解:优化原则和常见优化手法
    优化 c++++ 函数遵循原则:优化关键路径代码、关注热点函数、平衡性能与可读性。常见优化手法包括:内联函数消除函数调用开销;减少间接调用提高直接访问速度;优化循环提高效率;虚拟函数重写...
    99+
    2024-05-01
    优化 c++ 代码可读性
  • MYSQL配置参数优化详解
    MySQL参数优化对于不同的网站,及其在线量,访问量,帖子数量,网络情况,以及机器硬件配置都有关系,优化不可能一次性完成,需要不断的观察以及调试,才有可能得到最佳的效果。 1)连接请求的变量 1、max_...
    99+
    2024-04-02
  • C++ 函数优化详解:如何优化内存分配?
    优化 c++++ 内存分配:使用内存池: 预先分配特定大小的对象,减少创建和销毁开销。使用对象池: 存储已创建对象,便于重用,避免频繁分配。使用自定分配器: 优化标准库分配器的行为。避免...
    99+
    2024-05-03
    c++ 内存优化 标准库
  • C++ 函数优化详解:如何优化异常处理?
    c++++ 异常处理优化策略:避免抛出和捕获异常正确传播异常到更高层级使用 noexcept 规范声明不会抛出异常的函数只在需要时使用 try/catch 块使用异常规范指定函数可能抛出...
    99+
    2024-05-03
    c++ 函数优化
  • C++ 函数优化详解:如何优化模板代码?
    如何优化模板代码?内联展开:减少函数调用开销,提高性能。编译器优化:利用局部模板实例化、函数参数推导和内联常量。代码模板:提高代码可重用性,避免重复编写。避免不必要的类型转换:显式指定模...
    99+
    2024-05-01
    c++ 函数优化 隐式转换
  • C++ 函数优化详解:如何衡量优化效果?
    c++++ 函数优化效果衡量方法:使用性能分析工具生成执行时间报告。运行微基准测量特定函数或代码块的性能。分析函数算法复杂度以估计优化后提升。实战案例:优化斐波那契函数优化前:递归函数复...
    99+
    2024-05-02
    c++ 函数优化 linux
  • C++ 函数优化详解:如何优化泛型编程?
    c++++泛型函数优化技术包括:使用inline函数消除函数调用开销。使用constexpr函数在编译时计算函数值。利用局部类型推导减少代码冗余。通过函数模板特化进行针对性优化。通过实战...
    99+
    2024-05-03
    c++ 函数优化
  • C++ 函数优化详解:如何优化继承和多态?
    优化 c++++ 继承和多态:优化继承:使用虚拟继承避免菱形继承问题尽量避免多重继承将基类成员标记为 protected 或 private优化多态:使用虚函数代替函数重载谨慎使用 rt...
    99+
    2024-04-30
    c++ 函数优化
  • C++ 函数优化详解:如何优化时间复杂度?
    为了优化 c++++ 函数的时间复杂度,可以通过以下方法:①避免不必要的复制操作;②减少函数调用;③使用高效的数据结构。举例来说,采用备忘录技术可以将斐波那契数列计算的复杂度从 o(2^...
    99+
    2024-05-03
    c++ 函数优化
  • C++ 函数优化详解:如何优化多线程性能?
    优化多线程 c++++ 函数性能的关键技术包括:编译器优化标志(例如 -o3 和 -parallel)并发容器(例如 std::vector 和 std::list)同步原语(例如锁和原...
    99+
    2024-05-04
    多线程 性能优化 c++ 并发访问 标准库
  • C++ 函数优化详解:避免常见的优化陷阱
    避免过早优化,专注于实际性能瓶颈。谨慎内联函数,避免代码膨胀和编译时间变长。遵循 const 正确性准则,避免意外修改输入/输出。始终确保在使用前初始化局部变量。考虑缓存一致性,使用 v...
    99+
    2024-05-04
    c++ 函数优化 同步机制
  • C++ 函数优化详解:如何优化空间复杂度?
    减少 c++++ 函数的空间复杂度可通过以下技巧:使用智能指针、传递引用而非复制、使用常量引用、传递值而非指针、优化容器大小。通过使用智能指针、传递 token 所有权等实战技巧,可以减...
    99+
    2024-05-04
    c++ 函数优化 内存占用
  • PHP8如何使用Named Arguments优化函数调用?
    近日,PHP8正式发布,其中最引人注目的功能之一是Named Arguments(命名参数)。这个特性使得函数调用更具可读性和易维护性,使得代码可读性更高,也能大幅减少在编程中的犯错概率。本文将介绍PHP8的命名参数及其如何优化函数调用,且...
    99+
    2023-10-28
    PHP 函数调用 named arguments
  • MySQL COUNT函数的使用与优化
    COUNT 函数做什么用? COUNT 是一个专用的函数,通常有两种不同的方式:计算值和数据行。值指的是非空(Non-NULL)表达式(NULL表示值缺失)。如果我们在 COUNT的参数中指定了列名或其他表达式,则...
    99+
    2022-05-11
    MySQL COUNT的使用 MySQL COUNT的优化
  • C++ 函数优化详解:未来优化趋势与新技术
    c++++函数优化在未来将迎来原生支持、基于预测的优化和跨语言优化等趋势。新技术包括基于流的优化,允许实时优化函数;指导优化,提供用户提供的编译时指导;可信执行环境,增强安全性并允许激进...
    99+
    2024-05-01
    c++ 函数优化
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作