注释语法

    本文档介绍 TiDB 支持的注释语法。

    TiDB 支持三种注释风格:

    • 用 注释一行:

      1. +------+
      2. | 1+1 |
      3. +------+
      4. | 2 |
      5. +------+
      6. 1 row in set (0.00 sec)
    • -- 注释一行:

      1. SELECT 1+1; -- 注释文字
      1. +------+
      2. | 1+1 |
      3. | 2 |
      4. +------+
      5. 1 row in set (0.00 sec)

      -- 注释时,必须要在其之后留出至少一个空格,否则注释不生效:

      1. +--------+
      2. +--------+
      3. | 3 |
      4. +--------+
      5. 1 row in set (0.01 sec)
    • /* */ 注释一块,可以注释多行:

      1. SELECT 1 /* 这是行内注释文字 */ + 1;
      1. +--------+
      2. | 1 + 1 |
      3. +--------+
      4. +--------+
      5. 1 row in set (0.01 sec)
      1. +-------------------+
      2. | 1+
      3. 1 |
      4. | 2 |
      5. +-------------------+
      6. 1 row in set (0.001 sec)
    1. /*! Specific code */

    或者

    1. /*!50110 Specific code */

    和 MySQL 一样,TiDB 会执行注释中的语句。

    例如:SELECT /*! STRAIGHT_JOIN */ col1 FROM table1,table2 WHERE ...

    在 TiDB 中,这种写法等价于 SELECT STRAIGHT_JOIN col1 FROM table1,table2 WHERE ...

    如果注释中指定了 Server 版本号,例如 /*!50110 KEY_BLOCK_SIZE=1024 */,在 MySQL 中表示只有 MySQL 的版本大于等于 5.1.10 才会处理这个 comment 中的内容。但是在 TiDB 中,这个 MySQL 版本号不会起作用,所有的 comment 都被会处理。

    TiDB 也有独立的注释语法,称为 TiDB 可执行注释语法。主要分为两种:

    • /*T![feature_id] Specific code */:该语法用于保证 TiDB 不同版本之间的兼容性。只有在当前版本中实现了 feature_id 对应的功能特性的 TiDB,才会试图解析该注释里的 SQL 片段。例如 v3.1.1 中引入了 AUTO_RANDOM 特性,该版本能够将 /*T![auto_rand] auto_random */ 解析为 auto_random;而 v3.0.0 中没有实现 AUTO_RANDOM 特性,则上述 SQL 语句片段会被忽略。注意前几个字符 /*T![ 中,各字符之间没有任何空格

    还有一种注释会被当做是优化器 Hint 特殊对待:

    TiDB 支持的相关优化器 hint 详见 。

    更多细节,请参考 MySQL 文档