Postgresql使用update语句的方法示例

 更新时间:2024年04月13日 09:46:16   作者:一只小锦鲤_  
PostgreSQL是一种开源的关系型数据库管理系统,它支持SQL语言以及许多高级功能,如事务、外键、触发器等,下面这篇文章主要给大家介绍了关于Postgresql使用update语句的相关资料,需要的朋友可以参考下

解决问题

通过多张关联表更新主表的字段,根据状态更新为不同的值。

一、关联表更新

1.关联一张表

更新 table1 表中 num 字段的值为 table2 表中的 sum 的值

update table1 a
set a.num = b.sum
from table2 b
where a.id = b.rel_id and b.type = '1';

2.关联多张表

更新 table1 表中 num 字段的值为 table2 和 table3 表中的 sum 字段的和

update table1 a
set a.num = b.sum + c.sum
from table2 b
left join table3 c on b.id = c.rel_id
where a.id = b.rel_id and c.type = '1';
update table1 a
set a.num = b.sum + c.sum
from table2 b, table3 c
where a.id = b.rel_id and b.id = c.rel_id and c.type = '1';

二、根据状态更新为不同的值

根据 table2 表中的 type 的值,更新 table1 表中 num 字段的值

update table1 a
set a.num = case when b.type = '1' then b.sum else b.sum + 1 end
from table2 b
where a.id = b.rel_id;

根据 table3 表中的 type 的值,更新 table1 表中 num 字段的值为 table2 表中的值

update table1 a
set a.num = case when c.type = '1' then b.interest_sum else b.interest_sum + 1 end
from (
	select sum(interest) as interest_sum from table2 group by country
	) b
left join table3 c on b.rel_id = c.id
where a.rel_id = b.id and a.type = '1';

附:update对分区表使用的影响

在查询这个一对多进行update执行的时候,官网还对其分区表的分区键进行update后,会不会变更其分区进行了解读:

在分区表的情况下,更新一行有可能导致它不再满足其所在分区的分区约束。此时,如果这个行满足分区树中某个其他分区的分区约束,那么这个行会被移动到那个分区。 如果没有这样的分区,则会发生错误。在后台,行的移动实际上是一次DELETE操作和一次INSERT操作。

在移动的行上的并发UPDATE或DELETE可能会收到序列化失败错误。 假设会话 1 正在分区键上执行UPDATE,同时,对可访问该行的并发会话 2 在此行上执行UPDATE或DELETE操作。 在这种情况下,会话 2 的UPDATE 或 DELETE将检测行移动并引发序列化失败错误(该错误始终返回 SQLSTATE 代码"40001")。 如果发生这种情况,应用程序可能希望重试事务。 在通常情况下,表没有分区或没有行移动,会话 2 将标识新更新的行,并执行UPDATE/DELETE在此新行版本中。

请注意,虽然行可以从本地分区移动到外表分区(如果外数据包装器支持元组路由),但它们不能从外表分区移动到另一个分区。

总结 

到此这篇关于Postgresql使用update语句的文章就介绍到这了,更多相关Postgresql使用update内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • postgresql 实现将数组变为行

    postgresql 实现将数组变为行

    这篇文章主要介绍了postgresql 实现将数组变为行的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL日期时间字段类型选择指南

    PostgreSQL日期时间字段类型选择指南

    这段文章详细介绍了在PostgreSQL中选择合适的日期时间数据类型的方法,特别推荐使用timestampwithouttimezone类型来存储精确到微秒的日期和时间,文章对比了多种日期时间数据类型的特点和适用场景,并并并强调了避免使用varchar等存储日期时间的重要性
    2026-06-06
  • PostgreSQL完成按月累加的操作

    PostgreSQL完成按月累加的操作

    这篇文章主要介绍了PostgreSQL完成按月累加的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • Postgresql的docker部署及图形化界面管理

    Postgresql的docker部署及图形化界面管理

    PostgreSQL 是一款功能强大的开源关系型数据库,以其高度的标准兼容性和可扩展性而闻名,本文将从介绍postgresql的部署,包括nas服务端与windows可视化软件,感兴趣的朋友跟随小编一起看看吧
    2026-04-04
  • PostgreSQL拼接字符串的几种方法简单示例

    PostgreSQL拼接字符串的几种方法简单示例

    在PostgreSQL中有多种方式可以拼接字符串,这篇文章主要给大家介绍了关于PostgreSQL拼接字符串的几种方法,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • PostgreSQL数据库如何定期清理归档(pg_wal)日志

    PostgreSQL数据库如何定期清理归档(pg_wal)日志

    在⼀般的⽣产环境中,数据库都需要开启归档模式,下面这篇文章主要给大家介绍了关于PostgreSQL数据库如何定期清理归档(pg_wal)日志的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-05-05
  • Navicat设置PostgreSQL数据库的表主键ID自增的方法

    Navicat设置PostgreSQL数据库的表主键ID自增的方法

    这篇文章主要介绍了Navicat设置PostgreSQL数据库的表主键ID自增的方法,文章通过图文结合的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-06-06
  • PostgreSql 重建索引的操作

    PostgreSql 重建索引的操作

    这篇文章主要介绍了PostgreSql 重建索引的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • PostgreSQL 创建表分区

    PostgreSQL 创建表分区

    在pg里表分区是通过表继承来实现的,一般都是建立一个主表,里面是空,然后每个分区都去继承它。
    2009-09-09
  • PostgreSQL查看版本信息的操作

    PostgreSQL查看版本信息的操作

    这篇文章主要介绍了PostgreSQL查看版本信息的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01

最新评论