news 2026/6/13 10:33:23

IvorySQL 5.0+:助力 Oracle 平滑过渡至 PostgreSQL 的里程碑式产品

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
IvorySQL 5.0+:助力 Oracle 平滑过渡至 PostgreSQL 的里程碑式产品

作者:Yasir Hussain Shah,Data Bene 团队。

IvorySQL:一种“先进、功能完备、开源且兼容 Oracle 的 PostgreSQL 数据库,始终致力于保持 100% 兼容性,并可作为最新 PostgreSQL 的无缝替代”。

同时,这款引擎也是我们团队将各类外部 SQL 语句及应用适配至 PostgreSQL 时的首选工具!我们秉持平滑过渡、而非整体迁移的理念 —— 让旧数据库引擎向新引擎逐步切换,核心为降低迁移风险、优化实施效果。借助这类方案,能为实现这两大目标带来关键助力。

尽管 IvorySQL 最新主版本发布已有一段时间,但其中的全新特性依旧让我们倍感振奋,特此为大家分享。

新特性概览

IvorySQL 5.0 版本(5.0 发布说明)于 2025 年 11 月 25 日发布,随后在 2025 年 12 月 18 日推出 5.1 版本(5.1 发布说明)。这两个版本凝聚了 IvorySQL 团队的大量投入,不仅带来了多项高品质的功能优化,还完成了对 PostgreSQL 18 的兼容性适配。

IvorySQL v5 带来了一系列关键能力,包括:

  • PLiSQL—— 兼容 Oracle PL/SQL 的子集
  • Oracle 兼容包支持
  • Oracle 风格序列支持
  • v5.0增强能力包括:ROWID%TYPE%ROWTYPE以及嵌套子函数

我们尤其喜欢很多功能升级。

例如,IvorySQL 现在改进了NULL值处理逻辑,在兼容模式下(与 Oracle 的行为一致),NULL值现在被视为空字符串,以避免迁移过程中出现错误。以SELECT CONCAT ('a' || NULL)语句为例,IvorySQL 将返回结果'a',而非沿用 PostgreSQL 默认的NULL值返回逻辑。

我们非常喜欢的一项增强功能是:你现在可以嵌套函数和存储过程。函数能够嵌入到其他函数内部(类似于 Oracle 的包,但更简单,仅使用私有方法)。这让你能够在一个地方集中组织复杂的逻辑。

与之类似,系统还增加了对DO [ LANGUAGE lang_name ] 代码块 [USING IN | OUT | IN OUT, ...]语法的支持。

实测验证

目前,我们已基于该版本完成多类应用的迁移适配测试,适配对象规模跨度极大:既有仅包含少量包、存储过程及函数的轻量应用(约 10-50 个数据库对象),也有包含海量数据库对象的大型业务系统(约 5 万个对象,其中存储过程超 1 万个、数据库包达数百个)。

尽管后续仍需持续迭代、补充更多功能特性,但当前版本已能大幅降低从 Oracle 向 PostgreSQL 平滑过渡的实施成本,助力迁移工作高效落地。

若你计划亲自体验测试,IvorySQL 提供了丰富的快速上手方式,包括源码编译、容器部署等,甚至还支持 WASM 构建!WASM 的独特优势在于,无需在本地完成完整安装,即可在浏览器中直接运行 IvorySQL,便于快速验证语法兼容性并开展 PostgreSQL 体系的初步探索。

你可参照 IvorySQL 官方发布的相关文章,通过简单几步完成 IvorySQL-WASM 项目的本地部署。也可直接访问 IvorySQL 官网,体验在线托管的 WASM 版本。

后续规划

我们团队很高兴聘用 IvorySQL 项目的贡献者,目前我们团队已有多位贡献者加入 IvorySQL 的核心研发工作。其中 Cédric Villemain、Yasir Hussain Shah 等成员的贡献,已在 5.0 和 5.1 版本的发布说明中专门致谢 —— 未来我们还将吸纳更多优秀开发者参与项目建设。

针对下一个版本,我们已规划了多项重磅新特性开发工作,具体包括:

  • ENABLE / DISABLE约束语法支持
  • UTL_FILE包新增适配
  • Oracle 风格的CREATE TRIGGER触发器体(无需预先创建函数)
  • 支持 Oracle 旧式连接运算符(+)

我们同样期待社区为下一个版本持续贡献的研发成果落地。目前已有多项优质功能正处于积极开发与合入阶段,例如项目新晋贡献者 Rophy Tsai 近期新增了DBMS_OUTPUTDBMS_UTILITY包的适配支持 —— 这两个包是 Oracle 生态 SQL 代码库中应用极为广泛的工具包。该特性现已合入 IvorySQL 主分支,预计将随下一个小版本或主版本正式发布。

对于希望在无需对现有数据库逻辑和应用程序进行大量改造的前提下,完成向 PostgreSQL 迁移或探索 PostgreSQL 生态的开发者而言,IvorySQL(尤其是 5.x 系列版本)提供了一套切实可行的解决方案。直接迁移至 PostgreSQL 在部分场景下,可能需要对数据库对象和应用代码做出大量调整,而 IvorySQL 能够有效填补这一适配鸿沟,凭借更高的兼容性,助力开发者更平滑地完成 PostgreSQL 生态的落地与适配。

您还可以通过以下渠道深入了解 IvorySQL:

  • 官网 blog:https://www.ivorysql.org/zh-CN/blog
  • 社区活动:https://www.ivorysql.org/zh-CN/webinars-page
  • HOW 2025 相关会议录像:https://www.youtube.com/@ivorysql

值得一提的是,2026 年的 HOW 大会已确定于 4 月 26 日至 28 日举行,议题征集截止日期为 2026 年 2 月 27 日。

更多参考

  • PostgreSQL.org 发布的 IvorySQL 5.0 公告
  • GitHub 上的 IvorySQL 5.0 路线图

原文链接:

https://www.data-bene.io/en/blog/ivorysql-5

作者:Yasir Hussain Shah


HOW 2026 议题招募中

2026 年 4 月 27-28 日,由 IvorySQL 社区联合 PGEU(欧洲 PG 社区)、PGAsia(亚洲 PG 社区)共同打造的 HOW 2026(IvorySQL & PostgreSQL 技术峰会) 将再度落地济南。届时,PostgreSQL 联合创始人 Bruce Momjian 等顶级大师将亲临现场。

自开启征集以来,HOW 2026 筹备组已感受到来自全球 PostgreSQL 爱好者的澎湃热情。为了确保大会议题的深度与广度,我们诚邀您在 2026 年 2 月 27 日截止日期前,提交您的技术见解。

投递链接:https://jsj.top/f/uebqBc

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/5 22:57:44

SDPose-Wholebody在嵌入式Linux系统上的移植与优化

SDPose-Wholebody在嵌入式Linux系统上的移植与优化 如果你正在为智能摄像头、机器人或健身设备开发人体姿态识别功能,并且受限于嵌入式设备的算力和存储,那么这篇文章就是为你准备的。SDPose-Wholebody作为当前最先进的133点全身姿态估计模型&#xff0…

作者头像 李华
网站建设 2026/5/27 6:21:49

51单片机开发环境搭建全攻略:从Keil安装到STC-ISP烧录(附避坑指南)

51单片机开发环境搭建实战指南:从工具配置到烧录优化 1. 开发环境全景认知 51单片机作为嵌入式领域的经典架构,其开发流程主要包含三个核心环节:代码编写、编译调试和程序烧录。完整的工具链由Keil C51开发环境、STC-ISP烧录软件和USB驱动组成…

作者头像 李华
网站建设 2026/6/8 18:46:44

GTE-Pro联邦学习实践:跨企业隐私保护的语义模型训练

GTE-Pro联邦学习实践:跨企业隐私保护的语义模型训练 1. 当数据不能流动时,如何让模型共同成长 医疗集团A拥有百万级的影像诊断报告,银行B积累了十年的金融风控文本,制药公司C手握大量临床试验笔记——这些数据都极具价值&#x…

作者头像 李华
网站建设 2026/5/10 8:18:12

深度学习项目训练环境:从零到部署完整指南

深度学习项目训练环境:从零到部署完整指南 你是否曾经为了配置一个深度学习环境而焦头烂额?从安装CUDA、配置Python环境,到解决各种依赖冲突,这个过程往往要耗费数小时甚至数天。更让人头疼的是,好不容易配置好的环境…

作者头像 李华
网站建设 2026/6/10 21:59:09

Verilator从入门到精通:安装、配置与实战应用指南

1. Verilator简介与核心价值 Verilator是一款将Verilog/SystemVerilog代码转换为优化后C或SystemC模型的仿真工具。与传统的解释型仿真器不同,它采用编译型架构,通过静态代码分析和时序优化,能实现比传统仿真器快10-100倍的运行速度。我在去年…

作者头像 李华