设为首页 收藏本站
查看: 1145|回复: 0

[经验分享] oracle中的存储过程使用

[复制链接]

尚未签到

发表于 2018-9-26 06:00:02 | 显示全部楼层 |阅读模式
  一 存储过程的基本应用
  1 创建存储过程(SQL窗口)
  create or replace procedure update_staff
  as
  begin
  update staff set name = 'xy';
  commit;
  end update_staff;
  存储过程适合做更新操作,特别是大量数据的更新
  2 查看存储过程在数据字典中的信息(SQL窗口)
  select object_name,object_type,status from user_objects where lower(object_name) = 'update_staff'
  3 查看存储过程语句(SQL窗口)
  select * from user_source where lower(name) = 'update_staff'
  4 执行存储过程(Command窗口)
  execute update_staff;
  5 存储过程的优点
  ① 提高数据库执行效率。使用SQL接口更新数据库,如果更新复杂而频繁,则需要频繁得连接数据库。
  ② 提高安全性。存储过程作为对象存储在数据库中,可以对其分配权限。
  ③ 可复用性。
  二 带输入参数的存储过程
  1 创建存储过程(SQL窗口)
  create or replace procedure update_staff(in_age in number) as
  begin
  declare newage number;
  begin
  newage := in_age + 10;
  update staff set age = newage;
  commit;
  end;
  end update_staff;
  2 执行存储过程(Command窗口)
  execute update_staff(10);
  3 默认值
  只有in参数可以有默认值,比如
  create or replace procedure update_staff(in_name in varchar2,in_age in number default 20)
  调用时可只写execute update_staff('xy');
  三 带输出参数的存储过程
  1 创建存储过程(SQL窗口)
  create or replace procedure update_staff (in_age in number,out_age out number) as
  begin
  update staff set age = in_age;
  select age into out_age from student where num = 1;
  commit;
  end update_staff;
  存储过程没有显示制定返回值,但输出参数可以输出
  2 输出存储过程结果(Command窗口)
  set serverout on;
  declare age number;
  begin
  update_staff(20,age);
  dbms.output.put_line(age);
  end;
  四 带输入输出的存储过程
  其中最典型的应用是交换两个数的值
  1 创建存储过程(SQL窗口)
  create or replace procedure swap (param1 in out number, param2 in out number) as
  begin
  declare param number;
  begin
  param:=param1;
  param1:=param2;
  param2:=param;
  end;
  end swap;
  2 输出存储过程结果(Command窗口)
  set serverout on;
  declare p1 number:= 25;
  p2 number:=35;
  begin
  swap(p1,p2);
  dbms_output.put_line(p1);
  end;
  五 参数总结
  ①输入参数:有调用者传递给存储过程,无论存储过程如何调用该参数,该参数的值都不能被改变,可以认为该参数的值是只读的。
  ②输出参数:可以作为返回值来用。可以认为可写。
  ③输入输出参数:这中类型的参数和java方法中的参数最像,传入方法,可读可写(final标识符除外)。
  ④参数顺序总结如下:具有默认值的参数应该位于参数列表的末尾,因为有时用户需要省略该参数。没有默认值的参数可以遵循"in -> out -> in out"。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-602058-1-1.html 上篇帖子: expdp,impdp实现oracle备份及导入(一) 下篇帖子: oracle 11g 单机安装
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表