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

如何在单个 PostgreSQL 查询中更新多行?

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

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

PostgreSQL 单一查询更新多行

本文探讨如何在PostgreSQL数据库中使用单一查询更新多行数据。虽然PostgreSQL不支持直接更新多行,但可以通过几种方法实现此目标。

一种方法是结合使用UPDATE ... FROM语法和一个映射表。这允许更新多个列,并提供更大的灵活性。以下代码演示了这种方法:

<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>
登录后复制

可以根据需要添加更多列:

<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的INSERT ... ON CONFLICT ... UPDATE语法,它将插入和更新功能合并到单个查询中。但是,此方法需要在用于标识要更新行的列上创建一个唯一索引。

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

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