oracleupdate存储过程
A. oracle中的存储过程有什么作用,该怎么理解(数据更新的话用update语句不就完了吗)
1.存储过程可以使得程序执行效率更高、安全性更好,因为过程建立之后 已经编译并且储存到数据库,直接写sql就需要先分析再执行因此过程效率更高,直接写sql语句会带来安全性问题,如:sql注入
2.建立过程不会很耗系统资源,因为过程只是在调用才执行。
3.存储过程可以用于降低网络流量,存储过程代码直接存储于数据库中,所以不会产生大量T-sql语句的代码流量。
4.使用存储过程使您能够增强对执行计划的重复使用,由此可以通过使用远程过程调用 (RPC) 处理服务器上的存储过程而提高性能。RPC 封装参数和调用服务器端过程的方式使引擎能够轻松地找到匹配的执行计划,并只需插入更新的参数值。
5.可维护性高,更新存储过程通常比更改、测试以及重新部署程序集需要较少的时间和精力。
6.代码精简一致,一个存储过程可以用于应用程序代码的不同位置。
7.增强安全性:
a、通过向用户授予对存储过程(而不是基于表)的访问权限,它们可以提供对特定数据的访问;
b、提高代码安全,防止 SQL注入(但未彻底解决,例如,将数据操作语言--DML,附加到输入参数);
c、SqlParameter 类指定存储过程参数的数据类型,作为深层次防御性策略的一部分,可以验证用户提供的值类型(但也不是万无一失,还是应该传递至数据库前得到附加验证)。
B. oracle 存储过程里面有一条update语句会造成主键冲突 如何捕获这个异常 取消这个update 继续运行
使用begin end块把update语句的异常捕获后处理一下,就只会影响条记录,而不是回滚整批数据。
C. oracle的存储过程中,有2条update语句,那2次update是默认在同一个事务中还是分别执行相互没有影响
存储过程
里面。
如果你没有在两条
SQL
语句之间,写
Commit
/
rollback
之类的语句。
那么这2条
update
是默认在一个事务里面的。
D. 怎样把oracle的update语句改成存储过程
更新数据存储过程
CREATE OR REPLACE PROCEDURE update_emp_proc(myempno IN NUMBER,myename IN VARCHAR2) AS
BEGIN
UPDATE emp SET ename=myename WHERE empno=myempno;
END;
E. oracle存储过程中update语句一直在执行中,无法更新完成
可能这个表被别的用户锁了;
select sess.sid,
sess.serial#,
lo.oracle_username,
lo.os_user_name,
ao.object_name,
lo.locked_mode
from v$locked_object lo, dba_objects ao, v$session sess
where ao.object_id = lo.object_id
and lo.session_id = sess.sid;
--杀掉会话
alter system kill session 'sid,serial#';
F. oracle 存储过程循环执行update语句
其实二楼写的最简单,但对于新手,最好别那么写,至于1楼,如果数据不是很多,没必要搞个游标。你也可以看看我写的
create or replace procere P_Update(o_vc_message out varchar2)
is
type column1 is table of table1.column1%type index by binary_integer;
col1s column1;
type rid is table of rowid index by binary_integer;
rids rid;
temp table1.column1%type;
begin
select column1,rowid bulk collect into col1s,rids from table1;
if (column1.count != 0) then
for i in col1s.first..col1s.last loop
temp := col1s(i);--处理 col1s(i) 想干嘛干嘛
update table1 set column1 = temp where rowid = rids(i);
end loop;
end if;
o_vc_message := 'OK!';
exception
when others then
o_vc_message := 'exception happend.' || sqlcode || sqlerrm;
rollback;
return;
end P_Update;
如果仅仅是简单处理column1,比如加1什么的,就别搞那么复杂,一个sql就ok了。
G. oracle数据库update存储过程
update a
set a3=xx
where a1 in (
select distinct b2
from b
where b3 < add_months(sysdate,1))
H. oracle存储过程不能写update语句
你的commit呢?
你第一次update没有问题,可是你这是一个循环,当第二次update时就会出现问题的,你跟踪下,第一次执行时应该是通过的,报错应该是第二次执行的时候报的。
I. oracle存储过程update select怎么写急要。。。
update select属于关联更新,方法如下。
有以下两张表: