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;

更多:

相关推荐
坊钰2 小时前
【MySQL 数据库】数据类型
java·开发语言·前端·数据库·学习·mysql·html
糖醋_诗酒2 小时前
SQL122 删除索引
数据库
在下千玦2 小时前
#MongoDB 快速上手
数据库·mongodb
hxung2 小时前
springboot项目中常用的工具类和api
数据库·spring boot·后端
2401_874275172 小时前
微服务。1 微服务
java·数据库·微服务
网安小陈2 小时前
【网安】处理项目中的一些常见漏洞bug(java相关)
java·开发语言·数据库·安全·web安全·网络安全·bug
Gauss松鼠会3 小时前
GaussDB性能调优:从根因分析到优化落地
数据库·性能优化·database·gaussdb
꧁坚持很酷꧂3 小时前
Ubuntu远程连接Mysql数据库(图文详解)
数据库·mysql·ubuntu
花心蝴蝶.3 小时前
初识Redis
数据库·redis·缓存
小小鸭程序员4 小时前
在Spring Boot中实现图片上传和修改
java·数据库·python·mysql·spring