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;

更多:

相关推荐
呆呆小金人21 小时前
SQL视图:虚拟表的完整指南
大数据·数据库·数据仓库·sql·数据库开发·etl·etl工程师
笨手笨脚の21 小时前
Mysql 读书笔记
数据库·mysql·事务·索引·orderby·自增主键
码力引擎21 小时前
【零基础学MySQL】第四章:DDL详解
数据库·mysql·1024程序员节
程序新视界21 小时前
MySQL的隔离级别及其工作原理详解
数据库·后端·mysql
liliangcsdn21 小时前
如何基于llm+mysql构建轻量级全文搜索
数据库·人工智能·mysql
李慕婉学姐21 小时前
Springboot微信小程序在线考试系统w47h61gy(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·微信小程序
啊吧怪不啊吧21 小时前
SQL之表的查改(下)
大数据·数据库·sql
工具人55551 天前
adb disable-verity
数据库·数据仓库·adb
白露与泡影1 天前
Redis:我是如何与客户端进行通信的
数据库·redis·缓存
一只小bit1 天前
MySQL 索引:从聚簇到普通索引,如何加快查询效率?
数据库·mysql·oracle