oracle RETURNING 子句使用方法

这篇文章主要介绍了oracle RETURNING 子句使用方法,需要的朋友可以参考下

RETURNING 自己通常结合DML 语句使用。(INSERT UPDATE DELETE)

使用方法:

INSERT: 返回的是添加后的值
UPDATE:返回时更新后的值

DELETE:返回删除前的值

RETURNING 可以再sqlplus 和plsql中使用

如果是plsql就如上面的代码,xxx为声明的变量名

如果是sqlplus,xxx 可以为变量,即

这里的 :var_name 使用的是绑定变量

另外,RETURNING 貌似可以与 RETURN通用

INSERT INTO VALUES 支持 RETURNING

INSERT INTO SELECT、 和MERGE 语句 不支持 RETURNING

例子1:

建表语句:

CREATE SEQUENCE TEST111_S1
START WITH 1
INCREMENT BY 1
CACHE 20
MAXVALUE 999999999999999999999999999
CYCLE;

DECLARE
SEQ NUMBER;
BEGIN
INSERT INTO TEST111 VALUES(TEST111_S1.NEXTVAL,’AAA3′);
SELECT TEST111_S1.CURRVAL INTO SEQ FROM DUAL;
COMMIT;
DBMS_OUTPUT.PUT_LINE(SEQ);
END;

例子2:

再另外,RETURNING 可以与BULK COLLECT 结合(批量绑定, 另外一个是 FORALL)

FOR i IN v_tab.first .. v_tab.last LOOP
DBMS_OUTPUT.put_line( l_tab(i));
END LOOP;

COMMIT;
END;

ORA-06547:INSERT,UPDATE或DELETE语句必须使用RETURNING子句

产生这个错误的原因:

returning into子句作用于insert,update,delete,上而select则不行,应该用into。

报错的存储如下:

改成下面这样就ok了:

作者: dawei

【声明】:永州站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

为您推荐

联系我们

联系我们

0577-28828765

在线咨询: QQ交谈

邮箱: xwei067@foxmail.com

工作时间:周一至周五,9:00-17:30,节假日休息

返回顶部