当前位置: 首页 > news >正文

PostgreSQL和Oracle的sql差异

PostgreSQL和Oracle的sql差异

1.rownum

(1)Oracle分页查询使用rownum,PostgreSQL使用limit offset
ORACLEPOSTGRESQL
select * from (select rownum r,e.* from emp e where rownum <=5) t where r>0;select * from emp limit 5 offset 0;
(2)Oracle中rownum=1,PostgreSQL中使用limit 1
ORACLEPOSTGRESQL
select * from emp where rownum = 1;select * from emp limit 1;
(3)Oracle中序号列rownum,PostgreSQL使用窗口函数
ORACLEPOSTGRESQL
select rownum,t.* from emp t;select row_number() over(), t.* from emp t;

2.系统日期

ORACLEPOSTGRESQL
SYSDATEcurrent_timestamp, current_date

3.delete语句

Oracle delete语句可以没有from,pg必须要有from

ORACLEPOSTGRESQL
delete from emp where empno = xxx; delete emp where empno = xxxdelete from emp where empno = xxx

4.类型自动转换

Oracle支持类型自动转换,例如数字自动换换为字符串等;PG中需要显示转换,或者添加CAST

5.子查询别名

PostgreSQL在from关键字后的子查询必须要有别名,Oralce可以没有。

6. group by having

PG having语句必须在group by之后,oracle可以在group by之前

7.递归查询

Oracle中使用start with … connect by…, PG中使用with recusive

ORACLEPOSTGRESQL
select * from larearrelation where rearedgens = 1 and rearflag = 1 and rearlevel = ‘01’ connect by prior agentcode = rearagentcode start with rearagentcode = ‘10032226’;with recursive rs as ( select * from larearrelation where rearagentcode = ‘10032226’ union all select a. *from larearrelation a, rs where a.rearagentcode = rs.agentcode ) select ** from rs where rearedgens = 1 and rearflag = ‘1’ and rearlevel = ‘01’

  

8.update语句别名

postgresql中update语句时,set的字段不能有别名

ORACLEPOSTGRESQL
update emp t set t.name = ‘xxx’ where t.empno = 2update emp set name = ‘xxx’ where empno = 2

9. 日期相减

oracle日期相减自动转换为数字,结果为相差的天数。 pg日期相减为interval类型,得到相差天数需要进行类型转换

10.递归查询中的level

oracle的递归查询中level表示查询深度(或者递归层次),在PG中没有此含义的关键字,需要自行在with recursive实现

ORACLEPOSTGRESQL

select max(level) from larearrelation where rearedgens = 1 and rearflag = 1 and rearlevel = ‘01’

connect by prior agentcode = rearagentcode start with rearagentcode = ‘10032226’;

with recursive rs as (

  select larearrelation.*, 1 depth from larearrelation where rearagentcode = ‘10032226’

  union all

  select a./**, rs.depth + 1 depth from larearrelation a, rs where a.rearagentcode = rs.agentcode

)

select max(rs.depth) from rs where rearedgens = 1 and rearflag = ‘1’ and rearlevel = ‘01’

11.序列的调用

序列:  PostgreSQL 序列(SEQUENCE) - Merlin_Tang - 博客园

ORACLEPOSTGRESQL
select seqname.nextval from dual;select nextval(‘seqname’)

12.外连接

Oralce外连接支持使用 (+), PostgreSQL需使用left jion或者right join标准sql语法

13.distinct去重复

oracle支持unique关键字去重复,pg中只能使用distinct

14.字符串分割

ORACLEPOSTGRESQL
listaggstring_agg

15.集合相减

ORACLEPOSTGRESQL
Minusexcept

16.null与 ''

null和’’在oracle中是一致的,最终都会存储为null,在PG中会进行区分

17.不等于

Oracle中 ! =< >操作符中间允许有空格,PG中不可以

18.别名

PG中无效的别名,可以尝试加as关键字,例如name

19.正则表达式

ORACLEPOSTGRESQL
SELECT REGEXP_SUBSTR(‘17,20,23’,’,+’,1,1,’i’) FROM DUAL;select (regexp_matches(‘17,20,23’, ‘,+’))[1]

20.字段大小写

oracle字段名大写,PG字段名小写

 21.NVL --- COALESCE

ORACLEPOSTGRESQL
SELECT NVL(SUM(VALUE1),0) S_VALUE1 FROM   FIELD_SUM ;SELECT COALESCE(SUM(VALUE1),0) AS S_VALUE1  FROM   FIELD_SUM ;

 22.TO_NUMBER

ORACLEPOSTGRESQL
SELECT COL1 FROM A_TABLE ORDER BY TO_NUMBER(COL1);SELECT COL1 FROM A_TABLE ORDER BY TO_NUMBER(COL1, 999999)
[注:'999999' ---- 6位数为COL1字段的长度]

 23.DECODE --- CASE WHEN

ORACLEPOSTGRESQL
SELECT DECODE(ENDFLAG, '1', 'A', 'B') ENDFLAG FROM TEST;SELECT (CASE ENDFLAG WHEN '1' THEN 'A' ELSE 'B' END) AS ENDFLAG FROM TEST;

24.ADD_MONTHS

ORACLEPOSTGRESQL
add_months(date, int)

--创建函数来解决
CREATE FUNCTION add_months(date, int) 

RETURNS date AS 

'SELECT (1+(1+(2::text || ''months'')::interval)::date;' 

LANGUAGE 'sql'

25.LAST_DAY

ORACLEPOSTGRESQL
LAST_DAY(DATE)

--创建函数来解决
CREATE FUNCTION LAST_DAY(DATE)

RETURNS DATE AS

        'SELECT date(substr(text($1 +  interval(''1 month'')),1,7)||''-01'')-1'

LANGUAGE 'sql';

26.LAST_DAY

ORACLEPOSTGRESQL
LAST_DAY(DATE)

--创建函数来解决
CREATE FUNCTION LAST_DAY(DATE)

RETURNS DATE AS

        'SELECT date(substr(text($1 +  interval(''1 month'')),1,7)||''-01'')-1'

LANGUAGE 'sql';

http://www.lryc.cn/news/499669.html

相关文章:

  • SpringMvc完整知识点二(完结)
  • 29 - Java Serializable 序列化
  • 59 基于STM32的烟雾、红外、温湿度检测
  • 使用Excel 对S型曲线加减速算法进行仿真
  • flink-connector-mysql-cdc:01 mysql-cdc础配置代码演示
  • java计算机毕设课设—进销存管理系统(附源码、文章、相关截图、部署视频)
  • 鸿蒙UI开发——渐变色效果
  • 嵌入式硬件设计 — 智能设备背后的隐形架构大师
  • QNX的系统资源访问机制
  • 高校数字化运营平台解决方案:构建统一的服务大厅、业务平台、办公平台,助力打造智慧校园
  • 多模态大型语言模型MM-1.5采用数据驱动的方法,通过不断优化数据组合提高模型性能
  • 16 设计模式之适配器模式(充电器转换案例)
  • 基于Java Springboot在线招聘APP且微信小程序
  • 多组学数据如何发表高分SCI论文,以RNA-Seq数据为例
  • Qt Designer Ui设计 功能增加
  • 【Android学习】2024最新版Android Studio安装与配置
  • RabbitMQ延时队列
  • a8204 基于微信小程序的音乐播放器微信小程序的研究与实现 服务器端Java+Mysql+Servlet 文档 源码
  • 游戏新纪元:用栈记录数据,轻松实现悔棋功能
  • C/C++基础知识复习(36)
  • JAVA |日常开发中连接Sqlite数据库详解
  • Java项目实战II基于微信小程序的消防隐患在线举报系统(开发文档+数据库+源码)
  • python编程Day12-属性和方法的分类
  • 【unity小技巧】在 Unity 中,Application获取各种文件路径或访问不同类型的存储路径
  • c++:timer
  • VSCode(四)CMake调试
  • 安装Docker并使用WSL
  • HCIA-openGauss_2_2连接与认证
  • 安装 pytorch lighting
  • 2024年12月7日历史上的今天大事件早读