服务器之家

服务器之家 > 正文

PostgreSQL批量update与oracle差异详解

时间:2021-03-14 19:04     来源/作者:foucus、

上篇文章给大家介绍了PostgreSQL实现批量插入、更新与合并操作的方法 感兴趣的朋友可以点击查看,今天给大家分享PostgreSQL批量updateoracle差异,具体内容如下所示:

当我们在数据库中有这样的需求时:
需要以某列的当前值为判断对象,将其更新成其它值。

例如下面一张表:

?
1
2
3
4
5
6
7
   ID INFO
---------- ----------
     2 a
     1 b
     3 c
     4 d
     5 e

我们最简单的方式就是通过多个update来完成:

?
1
2
3
4
5
6
7
update t1 set id= 2
    where id = 1;
 
update t1 set id = 1
    where id = 2;
 
......

看上去很简单,但是上面的更新却存在一个很大的问题,当我们第一次执行完update后,表中id=2其实有两行数据,再去进行第二条语句时,两条语句将都会被更新。

显然这些并非我们的意愿,我们仅仅是希望id=1和id=2的值互换。

为了避免这个问题,我们可以使用case表达式来进行批量更新。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
SQL> update t1
 2 set id = case when id = 1
 3 then 2
 4 when id = 2
 5 then 1
 6 else id end;
 
5 rows updated.
 
SQL> select * from t1;
 
    ID INFO
---------- ----------
     2 a
     1 b
     3 c
     4 d
     5 e

这样不仅执行正确,而且只需要执行一次,自然更加高效。这个写法应用范围很广,例如我们可以很轻松实现主键值之间的互换。否则我们需要执行3次update才可以完成。

PostgreSQL差异点:

 

需要注意的是,在pg中使用该方法会因为主键重复而报错。

?
1
2
3
4
5
6
7
8
bill@bill=>update t2
set id = case when id = 1
then 2
when id = 2
then 1
else id end;
ERROR: duplicate key value violates unique constraint "t2_pkey"
DETAIL: Key (id)=(2) already exists.

但是,约束的检查应该是在更新完成后执行,所以在更新的过程中主键值出现重复应该没问题,
所以在Oracle中执行正常。

当然在pg中存在这种问题主要还是和pg的多版本特性有关。不过一般需要进行这种主键的调换的时候,我们可以先禁用掉约束即可。

到此这篇关于PostgreSQL批量update与oracle差异的文章就介绍到这了,更多相关PostgreSQL批量update内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_39540651/article/details/112259645

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
返回顶部