首页数据库PostgreSQL批量update与oracle差异详解

PostgreSQL批量update与oracle差异详解

时间2024-02-29 15:25:03发布访客分类数据库浏览789
导读:收集整理的这篇文章主要介绍了PostgreSQL批量update与oracle差异详解,觉得挺不错的,现在分享给大家,也给大家做个参考。 上篇文章给大家介绍了PostgreSQL实现批量...
收集整理的这篇文章主要介绍了PostgreSQL批量update与oracle差异详解,觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

例如下面一张表:

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

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

update t1 set id= 2	where id = 1;
    update t1 set id = 1	where id = 2;
    ......

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

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

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

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中使用该方法会因为主键重复而报错。

bill@bill=>
    update t2set id = case when id = 1then 2when id = 2then 1else 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内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

您可能感兴趣的文章:
  • 解决postgresql 数据库 update更新慢的原因
  • 基于postgresql行级锁for update测试
  • 实操MySQL+PostgreSQL批量插入更新insertOrUpdate
  • Postgres中UPDATE更新语句源码分析

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: PostgreSQL批量update与oracle差异详解
本文地址: https://pptw.com/jishu/633042.html
postgres主备切换之文件触发方式详解 如何获取PostgreSQL数据库中的JSON值

游客 回复需填写必要信息