oracle创建存储过程

创建一个存储过程,通过参数传递,分别显示出你的姓名、学号和成绩。谢谢了!!!Createtablelixiaoka3(Snonumber(15)primarykey,Sn... 创建一个存储过程,通过参数传递,分别显示出你的姓名、学号和成绩。

谢谢了!!!
Create table lixiaoka3
(Sno number(15) primary key,
Sname Varchar2(40) Not null,
Class Varchar2(10),
Ssex Varchar2(4) ,
Sage Number(4) ,
Grade Varchar2(10)
);
显示这个表的中相应信息的存储过程怎样创建?
我是这样创建的,但是提示ORA-01435: 用户不存在
如下:
CREATE OR REPLACE PROCEDURE lixiaoka3.xianshi
(V_Sno in number)
AS
BEGIN
select * from lixiaoka3;
END;
可请高手指教指教,谢谢了!!!
展开
 我来答
tpj_wow
2010-12-23 · TA获得超过532个赞
知道小有建树答主
回答量:232
采纳率:100%
帮助的人:293万
展开全部
--- 答案补充
1. lixiaoka3这个用户是不是不存在, 试试CREATE OR REPLACE PROCEDURE xianshi
2. 存储过程里面应该不能有单纯的select语句存在的, 你的select语句没有实际用处,即便查询出来了也看不到.如果要看这个表所有的数据的话,你可以做一个游标,然后把每个字段都put出来.
今至电子科技有限公司
2024-08-23 广告
数据库备份是确保数据安全与业务连续性的关键环节。我们上海今至电子科技有限公司高度重视数据保护,定期执行全面的数据库备份策略。这包括使用先进工具和技术,对关键业务数据进行自动化备份,并存储在安全可靠的外部存储介质或云端。通过定期验证备份的完整... 点击进入详情页
本回答由今至电子科技有限公司提供
liudan_198805
2010-12-25
知道答主
回答量:11
采纳率:0%
帮助的人:0
展开全部
你的procedure有以下问题:
1.估计你想创建一个procedure,并且这个procedure是对table:lixiaoka3进行操作,所以你
CREATE OR REPLACE PROCEDURE lixiaoka3.xianshi,但是在oracle里,这么写的话系统会认为你为user:lixiaoka3创建procedure,如果你数据库里还没有创建lixiaoka3这个用户,oracle当然会报没有用户的错误。附加一点,如果你的procedure和要操作的table在同一个用户下面的话,可以直接操作,默认有相应的权限。
2.你的procedure中有一条单纯的select 语句,这在plsql中是不允许的,必须要将你查询出来的数据into 到相应的变量、或记录、或游标或集合中,我看到你的procedure有一个in类型的“(V_Sno in number)”估计你想使用传入的V_Sno来查询学生信息,如果你要返回lixiaoka3的单行数据只需要使用到oracle的记录类型,具体可以这么写:
CREATE OR REPLACE PROCEDURE xianshi--把lixiaoka3表名去掉
(V_Sno in number)
AS
r_stu lixiaoka3%ROWTYPE;--定义一lixiaoka3表类型的记录变量
BEGIN
select * INTO r_stu from lixiaoka3 WHERE Sno=V_Sno;--将结果into 变量中

dbms_output.put_line(r_stu.Sname);--测试结果
END;

参考资料: self

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友7b25ad27
2010-12-21 · TA获得超过1853个赞
知道小有建树答主
回答量:1462
采纳率:0%
帮助的人:706万
展开全部
那不就是一个select语句吗 用的着写存储过程吗
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式