我有一个简单的表格:
NAME | TIMESTAMP | AMOUNT
--------------------------
Name1 | 123 | 1
Name2 | 123 | 15
Name3 | 124 | 3
Name4 | 125 | 1
等等。 现在我得到了一个新记录。如果名称和时间戳相等,我希望金额增加新记录的金额,否则应插入新记录。
类似于:
INSERT INTO test.data (NAME, TIMESTAMP, AMOUNT) values ('Name1', 123, 4)
IF not EXIST; OTHERWISE UPDATE test.data set AMOUNT + NEWAMOUNT where TIMESTAMP = oldTimestamp and NAME = oldName
这是否可以通过使用 Postgres 9.5 的一个简单的 sql 查询以某种方式实现?
谢谢
最佳答案
使用新的 on conflict
子句:
INSERT INTO test.data (NAME, TIMESTAMP, AMOUNT)
values ('Name1', 123, 4)
on conflict (name, timestamp)
do update
set AMOUNT + excluded.NEWAMOUNT
这需要您在(name, timestamp)
如果您不想让 (name, timestamp)
唯一,您可以使用可写的 CTE:
with new_values (name, timestamp, amount) as (
values ('Name1', 123, 4)
), changed as (
update data
set amount = amount + t.amount
from new_values nv
where data.name = nv.name
and data.timestamp = nv.timestamp
returning *
)
insert into data (name, timestamp, amount)
select name, timestamp, amount
from new_values
where not exists (select 1 from changed);
请注意(与on conflict
解决方案不同)这对于并发更新而言是不安全的,并且您可能会遇到竞争条件
关于sql - 我怎样才能在 Postgres 9.5 中做一些更新插入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35522886/