兼容性与使用限制

最近更新时间:2024-08-22 09:53:31

我的收藏
本文为您介绍只读分析引擎功能的使用限制和兼容性说明。
说明:
除本文中提到的支持场景,只读分析引擎均不支持其他特殊场景。

产品架构与可用性差异

TDSQL-C MySQL 版的读写实例和只读实例使用 存算分离架构 实现,在弹性性能与扩展性上具备天然优势。但是只读分析引擎与读写实例和普通的只读实例不同。为了确保在复杂查询场景下的极致性能,只读分析引擎使用的是存储与计算集中架构,其数据是存储于计算节点所在的同一服务器的本地磁盘中。基于此区别需要注意存在如下差异点:
只读分析引擎扩缩容需要搬迁数据,故在扩缩容场景下无法与读写实例和普通只读实例的效率保持一致。(当前版本暂不支持扩缩容)
只读分析引擎在单节点场景下,并不具备高可用能力,若节点存在故障则会导致此只读分析引擎不可用。若需要只读分析引擎能够为您提供连续服务,请申请多个只读分析引擎。

语法限制

在只读分析引擎中,只能执行只读的查询语句,无法对数据进行任何变更操作,包括 DDL 和 DML 操作。
在只读分析引擎中,仅支持 SELECT 查询语句。而 SELECT 语句中依然存在少量关键字与语法不支持,详细请见 SELECT 语句说明
在只读分析引擎中,支持 CTE 语法和窗口函数。但使用 CTE 语法和窗口函数依然存在部分限制,详细请见 CTE 语法使用说明窗口函数使用说明
只读分析引擎,暂时不支持全文检索语法。
如TDSQL-C MySQL 集群开启了只读分析引擎,则在“读写实例”中进行某些数据变更操作会导致只读分析引擎的数据加载出现异常,详细说明请参考 数据加载限制

值限制

在只读分析引擎中,默认普通列的支持的值大小限制为1MB,最大限制为5MB。若存在列值超过1MB的表,则在加载到分析引擎时会报错停止,可 提交工单 调整此限制值到5MB。若存在超出此大小的值,不建议将此对象加入到分析引擎。

SQL_MODE

和 MySQL 类似,只读分析引擎支持通过 SET [ SESSION | GLOBAL ] sql_mode='modes' 语句设置 SQL 模式来设置全局或者会话级别的 SQL Mode。也可以通过 SELECT @@sql_mode 来查询当前 SQL 的 SQL Mode。
只读分析引擎支持如下常见的 MySQL 系统 SQL_MODE,未提到的 SQL_MODE 均不支持。但需要注意的是虽然只读分析引擎支持这些 SQL_MODE,但是部分 SQL_MODE 在只读分析引擎中并不适用,如 NO_AUTO_CREATE_USER、NO_ENGINE_SUBSTITUTION 等。
名称
含义
PIPES_AS_CONCAT
将 || 视为字符串连接操作符 (+)(同 CONCAT()),而不视为 OR。
ANSI_QUOTES
将 " 视为识别符,如果启用 ANSI_QUOTES,只有单引号内的会被认为是 String Literals,双引号被解释为识别符,因此不能用双引号来引用字符串。
IGNORE_SPACE
若开启该模式,系统忽略空格。例如:“user”和“user ”是相同的。
ONLY_FULL_GROUP_BY
如果未被聚合函数处理或未被 GROUP BY 的列,出现在 SELECT、HAVING、ORDER BY 中,此 SQL 不合法。
NO_UNSIGNED_SUBTRACTION
在减运算中,如果某个操作数没有符号,不要将结果标记为 UNSIGNED(支持)。
NO_BACKSLASH_ESCAPES
若启用该模式,\\ 反斜杠符号仅代表它自己。
STRICT_TRANS_TABLES
对于事务存储引擎启用严格模式,insert 非法值之后,回滚整条语句。
STRICT_ALL_TABLES
对于事务型表,写入非法值之后,回滚整个事务语句。
NO_ZERO_IN_DATE
在严格模式时,不接受月或日部分为0的日期。如果使用 IGNORE 选项,我们为类似的日期插入“0000-00-00”。在非严格模式时,可以接受该日期,但会生成警告。
NO_ZERO_DATE
在严格模式时,不要将“0000-00-00”作为合法日期。您仍然可以用 IGNORE 选项插入0日期。在非严格模式时,可以接受该日期,但会生成警告。
ALLOW_INVALID_DATES
不检查全部日期的合法性,仅检查月份值是否在1至12之间,以及日期值是否在1到31之间,仅适用于 DATE 和 DATATIME 列,TIMESTAMP 列需要全部检查其合法性。
ERROR_FOR_DIVISION_BY_ZERO
启用该模式,在 INSERT 或 UPDATE 过程中,被除数为0值时,系统产生错误。若未启用该模式,被除数为0值时,系统产生警告,并用 NULL 代替。
REAL_AS_FLOAT
将 REAL 视为 FLOAT 的同义词,而不是 DOUBLE 的同义词。
NO_DIR_IN_CREATE
创建表时,忽视所有 INDEX DIRECTORY 和 DATA DIRECTORY 指令,该选项仅对从复制服务器有用。
NO_AUTO_CREATE_USER
防止 GRANT 自动创建新用户,但指定密码除外(但是在只读分析引擎中没有实际作用)。
NO_ENGINE_SUBSTITUTION
如果需要的存储引擎被禁用或未编译,可以防止自动替换存储引擎(但是在只读分析引擎中没有实际作用)。

字符集和排序规则

字符集(character set)是符号与编码的集合。只读分析引擎中的默认字符集是 utf8mb4。
排序规则(collation)是在字符集中比较字符以及字符排序顺序的规则。例如,在二进制排序规则中,比较 A 和 a 的结果是不一样的。
目前只读分析引擎支持的字符集和排序规则如下表:
字符集
描述
支持的排序规则
最大大小
utf8
UTF-8 Unicode
utf8_bin
3
utf8mb4
UTF-8 Unicode
utf8mb4_bin
4
注意:
当读写实例中的对象采用其他字符集时,对于数据加载至只读分析引擎不受任何影响,但是某一些特殊字符在只读分析引擎中进行查询时将存在异常,同时也会因为排序规则的不同导致排序结果不一致的情况出现。

其他行为说明

在只读分析引擎中执行 SELECT …… GROUP BY expr 的返回结果与 MySQL 8.0 保持一致,默认不排序,与 MySQL 5.7 会有一定区别,MySQL 5.7 会默认排序。因此,无论是在 MySQL 5.7 版本还是 MySQL 8.0 版本中构建的只读分析引擎,都是如此的逻辑。