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;

更多:

相关推荐
骑着王八撵玉兔3 分钟前
【性能优化与架构调优(二)】高性能数据库设计与优化
数据库·性能优化·架构
想要入门的程序猿1 小时前
Qt写入excel
数据库·qt·excel
Q_970956391 小时前
java+vue+SpringBoo校园失物招领网站(程序+数据库+报告+部署教程+答辩指导)
java·数据库·vue.js
Wyc724092 小时前
Maven
java·数据库·maven
程序猿小D2 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的电影小说网站管理系统,推荐!
java·数据库·mysql·spring·毕业设计·ssm框架·电影小说网站
羊小猪~~2 小时前
数据库学习笔记(十七)--触发器的使用
数据库·人工智能·后端·sql·深度学习·mysql·考研
背太阳的牧羊人2 小时前
Neo4j 的向量搜索(Neo4jVector)和常见的向量数据库(比如 Milvus、Qdrant)之间的区别与联系
数据库·neo4j·milvus
liulun3 小时前
在浏览器中使用SQLite(官方sqlite3.wasm)
数据库·sqlite·wasm
IT项目管理4 小时前
达梦数据库DMHS介绍及安装部署
linux·数据库
你都会上树?4 小时前
MySQL MVCC 详解
数据库·mysql