ORA-01422: 实际返回的行数超出请求的行数

论坛 期权论坛 编程之家     
选择匿名的用户   2021-6-2 20:40   2626   0

造成这个问题的原因是参数变量名称与Where条件字段名相同导致冲突

报错的代码
错误原因:因为我的参数sno 和搜索的字段名SNO 一样 (不能一样)
CREATE OR REPLACE
PROCEDURE "serchS" (sno IN VARCHAR2)
AS
v_name varchar2(20);
v_age varchar2(20);
BEGIN
SELECT SNAME INTO v_name FROM S WHERE SNO = sno;
DBMS_OUTPUT.PUT_LINE(v_name);
END;
/*--------------------------------------------------------------------------*/
改正后的代码
CREATE OR REPLACE
PROCEDURE "serchS" (sno2 IN VARCHAR2) //改变了变量名
AS
v_name varchar2(20);
v_age varchar2(20);
BEGIN
SELECT SNAME INTO v_name FROM S WHERE SNO = sno2; //改变了变量名
DBMS_OUTPUT.PUT_LINE(v_name);
END;

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:3875789
帖子:775174
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP