首页 > 数据库 > mysql教程 > 如何使用单个查询更新 PostgreSQL 中的多行?

如何使用单个查询更新 PostgreSQL 中的多行?

Linda Hamilton
发布: 2025-01-12 22:52:42
原创
367 人浏览过

How Can I Update Multiple Rows in PostgreSQL with a Single Query?

高效更新 PostgreSQL 中的多行

PostgreSQL 提供了同时更新多行的强大方法,避免了标准更新语句的限制。 本指南展示了一种非常有效的方法。

方法:利用UPDATE ... FROM子句

UPDATE ... FROM 语法提供了一种干净有效的方法来根据另一个源的数据更新多行。 这种“映射表”方法简化了一次更新多个列的过程。

例如,要根据相应的 column_a 值更新 column_b 值:

<code class="language-sql">UPDATE test AS t
SET column_a = c.column_a
FROM (VALUES
    ('123', 1),
    ('345', 2)
) AS c(column_b, column_a)
WHERE c.column_b = t.column_b;</code>
登录后复制

此查询使用 VALUES 子句来创建映射表。 扩展它来更新多个列很简单:

<code class="language-sql">UPDATE test AS t
SET column_a = c.column_a,
    column_c = c.column_c
FROM (VALUES
    ('123', 1, '---'),
    ('345', 2, '+++')
) AS c(column_b, column_a, column_c)
WHERE c.column_b = t.column_b;</code>
登录后复制

该技术提供了一种可扩展且灵活的解决方案,用于通过单个简洁的查询更新 PostgreSQL 中的多行。

以上是如何使用单个查询更新 PostgreSQL 中的多行?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板