Skip to content

Latest commit

 

History

History
146 lines (105 loc) · 3.4 KB

comment-syntax.md

File metadata and controls

146 lines (105 loc) · 3.4 KB
title category summary aliases
注释语法
reference
本文介绍 TiDB 支持的注释语法。
/docs-cn/dev/reference/sql/language-structure/comment-syntax/

注释语法

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

TiDB 支持三种注释风格:

  • # 注释一行:

    {{< copyable "sql" >}}

    SELECT 1+1;     # 注释文字
    +------+
    | 1+1  |
    +------+
    |    2 |
    +------+
    1 row in set (0.00 sec)
    
  • -- 注释一行:

    {{< copyable "sql" >}}

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

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

    {{< copyable "sql" >}}

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

    {{< copyable "sql" >}}

    SELECT 1 /* 这是行内注释文字 */ + 1;
    +--------+
    | 1  + 1 |
    +--------+
    |      2 |
    +--------+
    1 row in set (0.01 sec)
    

    {{< copyable "sql" >}}

    SELECT 1+
        -> /*
    /*> 这是一条
    /*> 多行注释
    /*> */
        -> 1;
    +-------+
    | 1+
    
    1 |
    +-------+
    |     2 |
    +-------+
    1 row in set (0.00 sec)
    

MySQL 兼容的注释语法

TiDB 也跟 MySQL 保持一致,支持一种 C 风格注释的变体:

/*! Specific code */

或者

/*!50110 Specific code */

在这种格式中,TiDB 会执行注释中的语句,这个语法是为了让这些 SQL 在其他的数据库中被忽略,而在 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 也有独立的注释语法,称为 TiDB 可执行注释语法,格式为 /*T![feature_id] XXX */。只有在当前版本中实现了 feature_id 对应的功能特性的 TiDB,才会试图解析该注释里的 SQL 片段。例如 v3.1.1 中引入了 AUTO_RANDOM 特性,该版本能够将 /*T![auto_rand] auto_random */ 解析为 auto_random;而 v3.0.0 中没有实现 AUTO_RANDOM 特性,则上述 SQL 语句片段会被忽略。

优化器注释语法

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

{{< copyable "sql" >}}

SELECT /*+ hint */ FROM ...;

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

注意

由于 TiDB 可执行注释语法和优化器注释语法在 MySQL 客户端 5.7.7 之前的版本中,会被默认当成 comment 清除掉,如果需要在旧的客户端使用这两种语法,需要在启动客户端时加上 --comments 选项,例如 mysql -h 127.0.0.1 -P 4000 -uroot --comments

更多细节,请参考 MySQL 文档