有没有Oracle相当于SQL Server的OUTPUT INSERTED.*?
发布时间:2020-12-12 13:47:35 所属栏目:百科 来源:网络整理
导读:在SQL Server中,您可以执行以下操作: INSERT INTO some_table (...) OUTPUT INSERTED.*VALUES (...) 这样你可以插入任意的列/值集合并将其返回.在Oracle中有什么办法吗? 最好的办法就是这样做: INSERT INTO some_table (...)VALUES (...)RETURNING ROWID
在SQL Server中,您可以执行以下操作:
INSERT INTO some_table (...) OUTPUT INSERTED.* VALUES (...) 这样你可以插入任意的列/值集合并将其返回.在Oracle中有什么办法吗? 最好的办法就是这样做: INSERT INTO some_table (...) VALUES (...) RETURNING ROWID INTO :out_rowid …使用:out_rowid作为绑定变量.然后使用第二个这样的查询: SELECT * FROM some_table WHERE ROWID = :rowid …但是这并不完全一样,它返回列内的所有内容,而不仅仅是我插入的列. 有没有更好的方法来做这个没有使用大量的PL / SQL,最好只有一个查询? 也许我不明白这个问题,但这不是吗? (你必须知道你想要什么)INSERT INTO some_table (...) VALUES (...) RETURNING some_column_a,some_column_b,some_column_c,... INTO :out_a,:out_b,:out_c,... @Vincent返回批量收集为多行插入工作仅与forall结合使用(换句话说,如果从集合中插入可以将“结果”检索到另一个) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |