本文探讨如何在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中文网其他相关文章!