openGauss 支持的四种兼容模式

383 阅读2分钟

openGauss 支持的四种兼容模式(A、B、PG、C)在 SQL 语法层面存在明显差异,下面按“典型语法/行为差异各模式表现”的对比方式


🎯 1. 空字符串与 NULL 的判定

表格

复制

典型写法A(Oracle)B(MySQL)PG(PostgreSQL)C(TD)
'' IS NULLTRUEFALSEFALSETRUE
'' = ''NULL(未知)TRUETRUENULL

👉 影响

  • A/C 模式下,前端或 ORM 传空字符串时,数据库内部会当成 NULL 存储,导致唯一索引、CHECK 约束行为与预期不符。
  • B/PG 模式保持原义,迁移 MySQL/PostgreSQL 时无需改动业务代码。

🎯 2. 日期/时间类型映射

表格

复制

源类型A(Oracle)B(MySQL)PG(PostgreSQL)C(TD)
DATETIMESTAMP(0)DATEDATETIMESTAMP(0)
TIMESTAMPTIMESTAMP(6)DATETIME/TIMESTAMPTIMESTAMPTIMESTAMP(6)

👉 影响

  • 在 A 模式下,Oracle 的 DATE 含时分秒,迁移到 openGauss 后字段类型自动变成 TIMESTAMP(0),避免精度丢失。
  • B 模式下可直接复用 MySQL 的 DATETIME 语义。

🎯 3. 分页与 LIMIT 语法

表格

复制

场景A(Oracle)B(MySQL)PG(PostgreSQL)C(TD)
基本分页ROWNUM / 子查询LIMIT x OFFSET yLIMIT x OFFSET yTOP n
FETCH 语法支持 ANSI FETCH FIRST支持 LIMIT支持 LIMIT/FETCH支持 TOP

👉 结论

  • 从 MySQL/PostgreSQL 迁移到 openGauss 时,B 或 PG 模式可 100 % 沿用原 LIMIT 写法;
  • A 模式需改写成 Oracle 风格(嵌套子查询 + ROWNUM)。

🎯 4. 字符串拼接

表格

复制

写法A(Oracle)B(MySQL)PG(PostgreSQL)C(TD)
``拼接逻辑 OR拼接拼接
CONCAT(str1,str2)支持支持支持支持

👉 注意

  • 在 B 模式中,|| 被解析为“逻辑 OR”,必须用 CONCAT() 或改写 SQL。

🎯 5. 双引号与大小写

表格

复制

规则A(Oracle)B(MySQL)PG(PostgreSQL)C(TD)
双引号 "col"区分大小写不区分(视为普通字符)区分大小写区分大小写
单引号 'str'字符串字符串字符串字符串

👉 迁移提示

  • 从 Oracle 迁移到 openGauss(A 模式)时,保留双引号即可;
  • 从 MySQL 迁移到 B 模式时,需去掉双引号,防止列名大小写敏感导致查询失败。

🎯 6. 自增/序列

表格

复制

机制A(Oracle)B(MySQL)PG(PostgreSQL)C(TD)
自增关键字SEQUENCE 或 IDENTITYAUTO_INCREMENTSERIAL / IDENTITYIDENTITY
插入显式 0允许允许(需额外参数)允许允许

👉 迁移提示

  • B 模式下,仅加载 dolphin 插件后才支持 AUTO_INCREMENT 语法。

🎯 7. 系统函数差异(部分高频函数)

表格

复制

函数A(Oracle)B(MySQL)PG(PostgreSQL)
当前日期SYSDATECURDATE()CURRENT_DATE
字符串长度LENGTH()CHAR_LENGTH() / LENGTH()LENGTH()
空值替换NVL()IFNULL()COALESCE()

✅ 一句话总结

  • Oracle 迁移 → 选 A 模式,注意空串变 NULL、DATE 变 TIMESTAMP。
  • MySQL 迁移 → 选 B 模式,需加载 dolphin 插件;||AUTO_INCREMENT 需改写。
  • PostgreSQL 迁移 → 选 PG 模式,语法基本零改动,官方推荐。
  • Teradata 迁移 → C 模式已废弃,不建议使用