tencent cloud

文档反馈

支持的语句场景和受限场景

最后更新时间:2023-03-13 12:12:23

    本文介绍并行查询能力支持的语句场景和受限场景。

    兼容语句场景

    云数据库 MySQL 已经实现了具备如下特征的 SQL 语句的并行查询处理,并在逐渐完善更多的功能场景。

    • 对于单表扫描:支持全表扫描、索引扫描、索引范围扫描、索引 REF 查询等扫描类型的正序、逆序扫描。
    • 对于多表连接:支持 Nested Loop Join 算法以及 Semi Join、Anti Join、Outer Join 等连接类型。
    • 对于子查询:支持 derived table 的并行。
    • 对于数据类型:支持带多种数据类型的查询,包括整型数据、字符型数据、浮点型数据、时间类型数据、以及(有运行时大小限制的)溢出类型数据。
    • 普通运算符和函数原则上不限。
    • 聚合函数支持 COUNT/SUM/AVG/MIN/MAX。
    • 支持 UNION/UNION ALL 查询。
    • 支持 traditional(默认格式)、json 和 tree 三种 EXPLAIN 格式。

    受限场景

    云数据库 MySQL 并行查询能力不支持的场景如下。

    限制项限制说明
    语句兼容性限制 非查询语句不支持并行查询,包括 INSERT ... SELECT 和 REPLACE ... SELECT。
    stored program 中的查询语句无法并行。
    prepared statement 中的查询语句无法并行。
    串行化隔离级别事务内的查询语句无法并行。
    加锁读语句无法并行,如 select for update/share lock。
    CTE 无法并行。
    表/索引兼容性限制 查询表为系统表/临时表/非 Innodb 表时无法并行。
    空间索引无法并行。
    全文索引无法并行。
    分区表无法并行。
    扫描方式为 index_merge 的表无法并行。
    表达式/ Field 兼容性限制 包含 Generated Column 、BLOB、TEXT、JSON、BIT 和 GEOMETRY 字段的表无法并行。
    BIT_AND、BIT_OR、BIT_XOR 类型的聚合函数无法并行。
    aggregation(distinct),如 SUM(DISTINCT)、COUNT(DISTINCT) 等聚合函数无法并行。
    GIS 相关函数(如 SP_WITHIN_FUNC、ST_DISTANCE 等)无法并行。
    用户自定义函数无法并行。
    json 相关的函数无法并行(如 json_length,json_type,JSON_ARRAYAGG 等)。
    XML 相关函数无法并行(xml_str)。
    用户锁相关的函数无法并行(is_free_lock,is_used_lock,release_lock, release_all_locks,get_lock)。
    sleep 函数、random 函数、GROUP_CONCAT 函数、set_user_var 函数、weight_string 函数无法并行。
    部分统计相关函数(STD/STDDEV/STDDEV_POP,VARIANCE/VAR_POP/VAR_SAMP)无法并行。
    子查询无法并行。
    窗口函数无法并行。
    rollup 无法并行。

    除了通过 并行查询兼容语句场景 可以查询到语句是否被执行并行查询外,您还可以通过查看并行查询执行计划与查看线程工作状态查询,详情参见 查看并行查询

    联系我们

    联系我们,为您的业务提供专属服务。

    技术支持

    如果你想寻求进一步的帮助,通过工单与我们进行联络。我们提供7x24的工单服务。

    7x24 电话支持