欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

如何执行oracle存储过程,就exec一下? 有大用

如何执行oracle存储过程,就exec一下?

 

不单单是exec一下,还是得分情况:

1.如果是命令窗口就用exec 存储过程名,举个栗子:

1
EXEC  procedure;--procedure是存储过程名                                    

 2.如果是PL/SQL窗口就用 begin  存储过程名  end; 举个栗子:

1
2
3
begin                                    
  procedure;--procedure是存储过程名                                    
end;                                    

 3.如果是程序中调用就用 call 存储过程名 ,举个栗子:

hibernateDao.excuteSqlUpdate("{Call proc_stuInfo()}");//存储过程proc_stuInfo
       


另附 存储过程创建方法:        

复制代码            
create or replace procedure pro_test--pro_test为存储过程名
is
temp varchar2(128);--temp为存储过程临时变量
bengin
    select count(*) into temp from TEST;--这里为什么会使用temp变量,下面会提到
    insert into TEST values(3,'sss',25,'asd');
    commit;--切记commit一下(提交)
end;
           
复制代码            

注意:在存储过程中是不能直接出现"select * from test",这种简单查询,必须将查询出来的数据放入存储过程变量中,如上所示的temp变量。

 

分类: oracl 初级        


来自 https://www.cnblogs.com/sdd53home/p/5169046.html



oracle存储过程(带参数的存储过程)

复制代码            
复制代码                

                
复制代码                    
带参数的存储过程

举例:为指定的员工涨100元的工资,打印涨前和涨后的工资

如果带参,需要指定是输入参数还是输出参数



create or replace procedure raisesalary(eno in number)

as

 ---定义一个变量保存涨前的薪水,引用emp中sal的类型作为psal的类型

 psal emp.sal%type;

begin

 ---得到员工涨前的薪水

 select sal into psal from emp where empno=eno;

 ---给该员工涨100

 update emp set sal=sal+100 where empno=eno;

 

 ---需不需要commit?

 ---注意:一般不在存储过程或者存储函数中 commit和rollback

 

 ---打印涨前和涨后的工资

 dbms_output.put_line('涨前:'||psal||'涨后:'||(psal+100));

end;

/



一般在调用存储过程或者函数的时候再commit,这样可以保证所有执行是在同一个事物中进行的

如:

begin

    raisesalary(7839);

    raisesalary(7566);

    commit;

end;

/
                   
复制代码                    

                

一般不在存储过程中commit或者rollback,而是在调用存储过程之后再提交或回滚,这样能把存储过程封装到一个事务中。

 
               
复制代码                

如果是命令窗口就用exec 存储过程名,举个栗子:

1.如果是命令窗口就用exec 存储过程名,举个栗子:

EXEC  procedure  ;--procedure是存储过程名                

 2.如果是PL/SQL窗口就用 begin  存储过程名  end; 举个栗子:

begin            

  procedure;--procedure是存储过程名            
end;            

 3.如果是程序中调用就用 call 存储过程名 ,举个栗子:

hibernateDao.excuteSqlUpdate("{Call proc_stuInfo()}");//存储过程proc_stuInfo
           
复制代码            

 

无为而治

来自  https://www.cnblogs.com/wangchuanfu/p/10960550.html




普通分类: