oracle 存储过程,输入学号,输出对应的信息,怎么修改啊??

createorreplaceproceduresel6_stu2(var_s#invarchar(10),var_snameoutstu2.sname%type,dat... create or replace procedure sel6_stu2
( var_s# in varchar(10),
var_sname out stu2.sname%type,
date_sage out stu2.sage%type,
ch_ssex out stu2.ssex%type
)is
begin
select sname,sage,ssex into var_sname,date_sage,ch_ssex from stu2 where s#=var_s#;
end sel6_stu2;
--------
declare
var_sname stu2.sname%type;
date_sage stu2.sage%type;
ch_ssex stu2.ssex%type ;
begin
sel6_stu2('100101',var_sname,date_sage,ch_ssex);--
dbms_output.put_line( '姓名:'||var_sname||',出生日期:'||date_sage||'性别:'||ch_ssex ); --
end;
------------------
100101 这条记录存在,错误如下:
展开
 我来答
Storm_duck
2014-09-05 · TA获得超过1629个赞
知道小有建树答主
回答量:1104
采纳率:82%
帮助的人:442万
展开全部
你在定义存储的时候,输入参数var_s#的数据类型varchar(10)改成varchar,不需要长度的。去掉后重新编译下存储,就可以了。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式