Oracle 迁移到 PostgreSQL

前言:因为公司技术调整,数据库需要从oracle替换为PostgreSQL,替换后很多地方需要对应调整,在此记录方便自己和大家避坑。
  • 数据类型
对比项 Oracle PostgreSQL
大文本 clob text
数字 NUMBER NUMERIC
可变长字符 VARCHAR2 VARCHAR
  • 函数
对比项 Oracle PostgreSQL
行号 rownum row_number() over(order by ...) as rownum
取一行 rownum = 1 limit 1 【注意排序】
null时赋值 nvl() coalesce()
转换为时间类型 to_date() to_timestamp()
字符串分隔 split() regexp_split_to_table()
子字符串所在位置查询【从1开始】 instr(String,subString) strpos(String,subString)
三元表达式 decode() case ... when ... then ... when ... then ...else ...end
树形查询 start with ... priority ... WITH RECURSIVE a AS ( select xx,1 as level from table1 where id = '123' union all select d.xx,a.level +1 from table1 d join a on d.pid = a.id) select * from a
  • 存储过程
对比项 Oracle PostgreSQL
当前时间 SYSDATE LOCALTIMESTAMP or CURRENT_TIMESTAMP
递增序列并返回新值 seq_xxx.nextval nextval('seq_xxx')
存储过程调用存储过程 proc_xxx(...) call proc_xxx(...)
退出游标循环 EXIT WHEN v_cursor%notfound; EXIT WHEN not found;

更多:

相关推荐
techdashen5 小时前
MySQL体系架构 - 简洁版
数据库·mysql·架构
+VX:Fegn08955 小时前
计算机毕业设计|基于springboot + vue旅游网系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
梁正雄5 小时前
linux服务-MariaDB 10.6 Galera Cluster 部署
android·数据库·mariadb
VX:Fegn08955 小时前
计算机毕业设计|基于springboot + vue小区居民物业管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
意法半导体STM325 小时前
【文末送NUCLEO-G431RB】一文说明白STM32G4双Bank启动与升级 LAT1596
前端·数据库·stm32·单片机·嵌入式硬件·mcu·stm32开发
7ioik5 小时前
深入了解 MySQL InnoDB 中 MVCC 与锁的具体协作流程
android·数据库·mysql
五阿哥永琪5 小时前
MySQL的最左前缀原则是什么?
数据库·mysql
BD_Marathon5 小时前
SpringMVC——bean加载控制
java·开发语言·数据库
Moresweet猫甜6 小时前
Ubuntu LVM引导丢失紧急救援:完整恢复指南
linux·运维·数据库·ubuntu
yumgpkpm6 小时前
Cloudera CDH5、CDH6、CDP7现状及替代方案
数据库·人工智能·hive·hadoop·elasticsearch·数据挖掘·kafka