我正在尝试从一个表中删除一行并将其与一些附加数据插入到另一个表中。我知道这可以通过两个单独的命令来完成,一个用于删除,另一个用于插入新表。然而我试图将它们结合起来但它不起作用,这是我到目前为止的查询:
insert into b (one,two,num) values delete from a where id = 1 returning one, two, 5;
运行时我收到以下错误:
错误:“删除”处或附近的语法错误
谁能指出如何实现这一点,或者有更好的方法吗?或者这是不可能的?
在 PostgreSQL 9.1 之前,您无法执行此操作,因为 PostgreSQL 9.1 尚未发布。然后语法是
WITH foo AS (DELETE FROM a WHERE id = 1 RETURNING one, two, 5)
INSERT INTO b (one, two, num) SELECT * FROM foo;
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)