工作中遇到的生僻sql语法汇总(长期更新)

这篇博客汇总了工作中遇到的一些不常见的SQL语法,包括根据主键是否存在执行不同操作、在PostgreSQL和Oracle中的用法、EXISTS子句的解释,以及如何将数据从一个表插入或更新到另一个表,特别提到了Oracle中的MERGE语法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

盘点工作中遇到的一些sql语法,若有任何问题请各位大佬不吝赐教

根据主键是否存在执行不同操作

postgreSql

详细用法可参考

-- id不存在时执行插入,存在则do nothing
insert into test values (1,'hello digoal',now()) on conflict (id) do nothing;
-- id不存在时执行插入,存在则update
insert into conflict_1(a,b,c) select a,b,c from conflict_2 on conflict (a) do update set a = excluded.a, b = excluded.b, c= excluded.c;

oracle

在Oracle中可以使用mergin语法
详细用法可参考

merge into target t using source s on (t.id = s.aid)
when matched then
update set t.year = s.year
when not matched then
insert values(s.aid, s.name, s.year);

exist

一种通俗的可以理解为:将外查询表的每一行,代入内查询作为检验,如果内查询返回的结果取非空值,则EXISTS子句返回TRUE,这一行行可作为外查询的结果行,否则不能作为结果。

SELECT * FROM AM_USER WHERE EXISTS (SELECT 1 FROM AM_ROLE WHERE NAME = 'admin')

将一个表的数据插入另一个表

Insert into Table2(field1,field2,...) select value1,value2,... from Table1

将一个表的数据更新至另一个表

oracle写法

UPDATE A  SET (A1, A2, A3) = (SELECT B1, B2, B3 FROM B WHERE A.ID = B.ID)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值