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;

更多:

相关推荐
百***81279 小时前
【HTML+CSS】使用HTML与后端技术连接数据库
css·数据库·html
6***3499 小时前
MySQL项目
数据库·mysql
木井巳9 小时前
【MySQL数据库】数据库基础
数据库·mysql
Wang's Blog9 小时前
MySQL: 查询全流程深度解析与性能优化实践指南
数据库·mysql·性能优化
一 乐10 小时前
宠物管理|宠物共享|基于Java+vue的宠物共享管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·springboot·宠物
Wang's Blog10 小时前
MongoDB小课堂: 高级查询操作符与游标管理综合指南之深度整合逻辑操作符、字段处理、数组查询与游标控制的最佳实践
数据库·mongodb
垂金烟柳10 小时前
MongoDB GridFS 历史数据自动化清理实践
数据库·mongodb·自动化
白露与泡影10 小时前
MySQL中的12个良好SQL编写习惯
java·数据库·面试
foundbug99910 小时前
配置Spring框架以连接SQL Server数据库
java·数据库·spring
q***318910 小时前
mysql 迁移达梦数据库出现的 sql 语法问题 以及迁移方案
数据库·sql·mysql