加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

有没有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结合使用(换句话说,如果从集合中插入可以将“结果”检索到另一个)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读