MySQL数据库兼容性概述
本章节主要介绍GaussDB数据库的M-Compatibility兼容模式与MySQL5.7数据库的兼容性对比信息。仅介绍505.1版本后新增的兼容性特性,特性的相关规格和约束建议在开发指南中查看。
GaussDB数据库在数据类型、SQL功能和数据库对象等基本功能上与MySQL数据库兼容。
GaussDB的执行计划和优化、explain显示结果与MySQL不同。
由于GaussDB数据库与MySQL数据库底层框架实现存在差异,GaussDB数据库与MySQL数据库仍存在部分差异。
由于M-Compatibility的底层架构与MySQL存在差异,对于information_schema和m_schema下与MySQL名称相同的Schema(具体参见M-Compatibility开发指南第六章),其查询性能可能存在差异。例如count函数无法做执行上的优化,表现为select *和select count(*)语句耗时近似。
Database和Schema设计
MySQL的数据对象包括DATABASE、TABLE、INDEX、VIEW、TRIGGER、PROC等,MySQL的对象层次跟GaussDB的对应关系是从上至下且一对多包含关系。如下图所示:
- 在MySQL中Database和Schema是同义词;而在GaussDB中,一个Database 下可以有多个Schema。在该特性中,每个MySQL中的Database都被映射到GaussDB的一个Schema。
- 在MySQL中,INDEX从属于一个TABLE,但在GaussDB中,INDEX从属于一个Schema。这个差异导致INDEX名在GaussDB中要求在Schema内唯一,但在MySQL中仅要在在一个表内唯一。这个差异将作为当前约束予以保留。