基于开源可控的国产数据库之路 - huodongjia.com · 2017. 11. 4. ·...

22
2017 Postgres大象会 PGConf.CN 2017 基于开源可控的国产数据库之路 Oracle兼容在PG上的实践) 嘉宾:王颖泽 公司:天曦网络科技(北京)有限公司 邮箱:[email protected] 网址:http://www.txtechnologies.com 二维码 或Logo

Upload: others

Post on 12-Feb-2021

6 views

Category:

Documents


0 download

TRANSCRIPT

  • 2017 Postgres大象会 PGConf.CN 2017

    基于开源可控的国产数据库之路(Oracle兼容在PG上的实践)

    嘉宾:王颖泽

    公司:天曦网络科技(北京)有限公司

    邮箱:[email protected]

    网址:http://www.txtechnologies.com

    二维码或Logo

  • 2017 Postgres大象会 PGConf.CN 2017

    为什么要去‘O’

  • 2017 Postgres大象会 PGConf.CN 2017

    去'O'面临的问题

  • 2017 Postgres大象会 PGConf.CN 2017

    如何去‘O’

  • 2017 Postgres大象会 PGConf.CN 2017

    为什么选择PG

  • 2017 Postgres大象会 PGConf.CN 2017

    PG在Oracle兼容方面的现状➢ PG:PG的官方文档中有一些对Oracle兼容方面的描述,例如:Porting from Oracle

    PL/SQL等;PG的wiki中也有不少资料,例如Oracle to Postgres Conversion等;

    ➢ 插件或工具:OraFCE,ora2pg,Full Convert,DBConvert,ESF Database Migration Toolkit等;

    ➢ 解决方案:很多公司都提供Oracle迁移到PG的解决方案,例如:2ndQuadrant,postgrespro;

    ➢ 产品:EnterpriseDB;

    ➢ 其他:网上有很多相关资料,例如“卸甲笔记”系列等。

    https://www.postgresql.org/docs/9.5/static/plpgsql-porting.htmlhttps://wiki.postgresql.org/wiki/Oracle_to_Postgres_Conversion

  • 2017 Postgres大象会 PGConf.CN 2017

    产品设计原则

    ➢ 尽量避免改动底层或核心代码;

    ➢ 保证修改代码的独立性;

    ➢ 尽量利用PG现有机制;

    ➢ 完全兼容PG;

    ➢ 跟随PG的版本升级;

    ➢ 不只语法兼容,还要关注功能和性能。

  • 2017 Postgres大象会 PGConf.CN 2017

    产品架构图

  • 2017 Postgres大象会 PGConf.CN 2017

    产品规划

    目标:支持Oracle的常用功能:平滑迁移,少改应用

    从三个方面对产品进行全方位的Oracle兼容设计:

  • 2017 Postgres大象会 PGConf.CN 2017

    产品规划 — 内核(SQL)SQL解析器 数据类型 内置函数 同义词 DDL

    Merge Into 伪表 ROWNUM 触发器 用户管理

  • 2017 Postgres大象会 PGConf.CN 2017

    产品规划—内核(PL/SQL)PL/SQL解析器 基本语法 动态SQL 匿名块 游标 RECORD

    OUT参数 搜索路径 集合类型 嵌套子程序 异常 PL/SQL加密

  • 2017 Postgres大象会 PGConf.CN 2017

    产品规划 — 接口

  • 2017 Postgres大象会 PGConf.CN 2017

    产品规划 — 工具

    备份恢复工具迁移工具 管理工具

  • 2017 Postgres大象会 PGConf.CN 2017

    产品规划 — 迁移工具

  • 2017 Postgres大象会 PGConf.CN 2017

    pl/sql到pl/pgsql的转换功能

    自动转换 代码对比 错误标记 修改保存 PL/SQL入库

  • 2017 Postgres大象会 PGConf.CN 2017

    ROADMAP — 内核(SQL)

  • 2017 Postgres大象会 PGConf.CN 2017

    ROADMAP—内核(PL/SQL)

  • 2017 Postgres大象会 PGConf.CN 2017

    ROADMAP — 接口

  • 2017 Postgres大象会 PGConf.CN 2017

    ROADMAP — 工具

  • 2017 Postgres大象会 PGConf.CN 2017

    感悟

    不忘初心!

    砥砺前进!

    希望最终能实现“基于开源可控的国产数据库”之梦!

  • 2017 Postgres大象会 PGConf.CN 2017

    致敬

    向EnterpriseDB致敬!

    向一直致力于替代Oracle的国产数据库同行致敬!

    向PostgreSQL的社区以及广大的PG用户及爱好者致敬!

  • 2017 Postgres大象会 PGConf.CN 2017

    Thanks! 二维码或Logo