openGauss 支持的四种兼容模式

openGauss 支持的四种兼容模式(A、B、PG、C)在 SQL 语法层面存在明显差异,下面按"典型语法/行为差异各模式表现"的对比方式,给出一份可直接落地的速查表。所有信息均来自官方文档及社区最新资料(截至 2024-10)。


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

表格

复制

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

👉 影响

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

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

表格

复制

源类型 A(Oracle) B(MySQL) PG(PostgreSQL) C(TD)
DATE TIMESTAMP(0) DATE DATE TIMESTAMP(0)
TIMESTAMP TIMESTAMP(6) DATETIME/TIMESTAMP TIMESTAMP TIMESTAMP(6)

👉 影响

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

🎯 3. 分页与 LIMIT 语法

表格

复制

场景 A(Oracle) B(MySQL) PG(PostgreSQL) C(TD)
基本分页 ROWNUM / 子查询 LIMIT x OFFSET y LIMIT x OFFSET y TOP 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)
自增关键字 SEQUENCEIDENTITY AUTO_INCREMENT SERIAL / IDENTITY IDENTITY
插入显式 0 允许 允许(需额外参数) 允许 允许

👉 迁移提示

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

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

表格

复制

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

✅ 一句话总结

  • Oracle 迁移 → 选 A 模式,注意空串变 NULL、DATE 变 TIMESTAMP。
  • MySQL 迁移 → 选 B 模式 ,需加载 dolphin 插件;||AUTO_INCREMENT 需改写。
  • PostgreSQL 迁移 → 选 PG 模式,语法基本零改动,官方推荐。
  • Teradata 迁移 → C 模式已废弃,不建议使用
相关推荐
计算机毕设VX:Fegn08957 小时前
计算机毕业设计|基于springboot + vue蛋糕店管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
没差c8 小时前
springboot集成flyway
java·spring boot·后端
三水不滴8 小时前
Redis 过期删除与内存淘汰机制
数据库·经验分享·redis·笔记·后端·缓存
笨蛋不要掉眼泪9 小时前
Spring Boot集成LangChain4j:与大模型对话的极速入门
java·人工智能·后端·spring·langchain
sheji341611 小时前
【开题答辩全过程】以 基于SpringBoot的疗养院管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
短剑重铸之日12 小时前
《设计模式》第六篇:装饰器模式
java·后端·设计模式·装饰器模式
码界奇点13 小时前
基于Flask与OpenSSL的自签证书管理系统设计与实现
后端·python·flask·毕业设计·飞书·源代码管理
代码匠心14 小时前
从零开始学Flink:状态管理与容错机制
java·大数据·后端·flink·大数据处理
分享牛14 小时前
LangChain4j从入门到精通-11-结构化输出
后端·python·flask
知识即是力量ol15 小时前
在客户端直接上传文件到OSS
java·后端·客户端·阿里云oss·客户端直传