当前位置:首页 » 存储配置 » 编译存储过程

编译存储过程

发布时间: 2022-02-14 04:21:38

Ⅰ 用什么命令可以重新编译所有的存储过程

这是我同事做的一个存储过程,我们一般都用这个处理
CREATE OR REPLACE PROCEDURE OWN.P_HSJ_COMPRE
IS
CURSOR cur_invalid_obj IS
SELECT uo.object_name,uo.object_type
FROM user_objects uo,
USER_ORDER_OBJECT_BY_DEPEND uobd
WHERE uo.object_id = uobd.object_id(+) AND uo.status != 'VALID'
ORDER BY uobd.dlevel desc,uo.object_type,uo.object_name;
ls_objname VARCHAR2(100);
ls_objtype VARCHAR2(100);
ls_status VARCHAR2(20);
ls_text VARCHAR2(4000);
ls_sql varchar2(100);
BEGIN
OPEN cur_invalid_obj;
LOOP
FETCH cur_invalid_obj INTO ls_objname,ls_objtype;
EXIT WHEN cur_invalid_obj%NOTFOUND;
IF ls_objtype IN ('PACKAGE BODY', 'PACKAGE', 'FUNCTION', 'PROCEDURE','TRIGGER', 'VIEW') THEN
if ls_objtype ='VIEW' then
ls_sql :=' ALTER VIEW '||LS_OBJNAME ||' COMPILE';
execute immediate ls_sql;
else
DBMS_DDL.alter_compile(ls_objtype,NULL,ls_objname);
end if;
SELECT status INTO ls_status FROM user_objects
WHERE object_name = ls_objname AND object_type = ls_objtype;
/* IF ls_status != 'VALID' THEN
SELECT text INTO ls_text FROM user_errors
WHERE name = ls_objname AND type = ls_objtype;
END IF;
*/
END IF;
END LOOP;
CLOSE cur_invalid_obj;
EXCEPTION
WHEN OTHERS THEN
IF cur_invalid_obj%ISOPEN THEN
CLOSE cur_invalid_obj;
END IF;
END;
/

Ⅱ plsql编译存储过程

字符转日期也不是你那种用法啊,应该用to_date,最后改成如下这样:
1
executeimmediate 'delete from car where underwriteenddate> to_date(''2017-05-07'',''yyyy-mm-dd'')';

Ⅲ PLSQL修改了存储过程如何编译保存

如果是在plsql developer中修改的,可以直接点那个齿轮图标,或者F8即可编译。
如果是在sqlplus中,那就敲入修改后的过程代码(create or replace procere...),最后以/结尾运行即可。

Ⅳ 存储过程经过编译保存在数据库中这句话对吗

这句话没有问题啊

存储过程在创建时就在数据库服务器上进行了编译并存储在数据库中了,存储过程运行要比单个的SQL语句块要快。并且在调用时只需要提供存储过程名和必要的参数信息,所以在一定程度上也可以减少网络流量、减轻网络负担。所以在项目中会选择将一些复杂的sql业务逻辑转用存储过程来实现以提高系统的性能

Ⅳ 存储过程和预编译有什么区别

绝对不一样 但细节没有十分的把握说准,看看其他高手

补充:嗯,你的说法是对的,但预编译的代码一般后面会很快用到,但数据库的存储过程不一定会经常用到

Ⅵ 如何编译 mysql的存储过程

简单的说,就是一组SQL语句集,功能强大,可以实现一些比较复杂的逻辑功能,类似于JAVA语言中的方法;
ps:存储过程跟触发器有点类似,都是一组SQL集,但是存储过程是主动调用的,且功能比触发器更加强大,触发器是某件事触发后自动调用;

Ⅶ 如何在Oracle中重编译所有无效的存储过程

:在SQL_PLUS中:spool ExecCompProc.sql select 'alter procere ' ||object_name||' compile;' From all_objects where status = 'INVALID' and object_type = 'PROCEDURE'; spool off @ExecCompProc.Sql;整理成一个存储过程:Create Or Replace Procere Zl_Compile_Invalid_Procere AsStrsql Varchar2(200);BeginFor x In (Select Object_Name From All_Objects Where Status = 'INVALID' And Object_Type = 'PROCEDURE') LoopStrsql := 'Alter Procere ' || x.Object_Name || ' Compile';Begin Execute Immediate Strsql; Exception--When Others Then Null; When OTHERS Then dbms_output.put_line(Sqlerrm); End;End Loop;End;最后执行:exec Zl_Compile_Invalid_Procere;如果要看到无法重编译的过程的出错信息,需要执行前设置set serverout on。

Ⅷ Oracle有没有命令可以编译存储过程

sqlplus有相关的了命令:比如alter procere prodere_name compile;
第一次编译的时候只要在后面加一个/当做执行符号,那么就可以进行编译。

Ⅸ oracle中如何批量编译视图和存储过程

1.批量编译存储工程的存储过程
create or replace procere compile_invalid_proceres(
p_owner varchar2 -- 所有者名称,即 SCHEMA) as--编译某个用户下的无效存储过程
str_sql varchar2(200);begin
for invalid_proceres in (select object_name from all_objects
where status = 'INVALID' and object_type = 'PROCEDURE' and owner=upper(p_owner))loop
str_sql := 'alter procere ' ||invalid_proceres.object_name || ' compile';begin
execute immediate str_sql;exception
--When Others Then Null;
when OTHERS Then
dbms_output.put_line(sqlerrm);end;end loop;end;
2.批量编译视图的存储过程

热点内容
我的零钱通密码是多少 发布:2025-03-16 05:04:36 浏览:933
编程猫酷跑 发布:2025-03-16 04:58:35 浏览:316
控制算法规律 发布:2025-03-16 04:54:17 浏览:960
tcl门锁原始设置密码是多少 发布:2025-03-16 04:52:37 浏览:985
如何给wifi加密码 发布:2025-03-16 04:52:05 浏览:361
linux的yes 发布:2025-03-16 04:38:20 浏览:832
诛仙脚本吧 发布:2025-03-16 04:31:00 浏览:37
java选择文件 发布:2025-03-16 04:29:20 浏览:825
android手机号码获取 发布:2025-03-16 04:14:42 浏览:873
为什么没有dns服务器可以上网 发布:2025-03-16 04:13:04 浏览:647