PostgreSQL与Oracle的sql区别有哪些
本篇内容介绍了“PostgreSQL与Oracle的sql区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
1.rownum(1)Oracle分页查询使用rownum,PostgreSQL使用limit offsetOracle delete语句可以没有from,pg必须要有from
delete emp where empno = xxxdelete from emp where empno = xxx4.类型自动转换
Oracle支持类型自动转换,例如数字自动换换为字符串等;PG中需要显示转换,或者添加CAST
5.子查询别名PostgreSQL在from关键字后的子查询必须要有别名,Oralce可以没有。
6. group by havingPG having语句必须在group by之后,oracle可以在group by之前
7.递归查询Oracle中使用start with … connect by…, PG中使用with recusive
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的字段不能有别名
oracle日期相减自动转换为数字,结果为相差的天数。
pg日期相减为interval类型,得到相差天数需要进行类型转换
oracle的递归查询中level表示查询深度(或者递归层次),在PG中没有此含义的关键字,需要自行在with recursive实现
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.序列的调用
Oralce外连接支持使用 (+), PostgreSQL需使用left jion或者right join标准sql语法
13.distinct去重复oracle支持unique关键字去重复,pg中只能使用distinct
14.字符串分割null和’’在oracle中是一致的,最终都会存储为null,在PG中会进行区分
17.不等于Oracle中 ! =,< >操作符中间允许有空格,PG中不可以
18.别名PG中无效的别名,可以尝试加as关键字,例如name
19.正则表达式oracle字段名大写,PG字段名小写
“PostgreSQL与Oracle的sql区别有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。