Pro*C

Oracle PLSQL游标、游标变量的使用

房东的猫 提交于 2020-04-25 04:50:12
参考文章: https://www.cnblogs.com/huyong/archive/2011/05/04/2036377.html 在 PL/SQL 程序中,对于处理多行记录的事务经常使用游标来实现 使用有四个步骤:定义、打开、提取、关闭 例子: 09:52:04 SCOTT@std1> DECLARE 09:52:07 2 CURSOR c_cursor 09:52:07 3 IS SELECT ename, sal 09:52:07 4 FROM emp 09:52:07 5 WHERE rownum<11; 09:52:07 6 v_ename emp.ename%TYPE; 09:52:07 7 v_sal emp.ename%TYPE; 09:52:07 8 BEGIN 09:52:07 9 OPEN c_cursor; 09:52:07 10 FETCH c_cursor INTO v_ename, v_sal; 09:52:07 11 WHILE c_cursor%FOUND LOOP 09:52:07 12 DBMS_OUTPUT.PUT_LINE(v_ename||'---'||to_char(v_sal) ); 09:52:07 13 FETCH c_cursor INTO v_ename, v_sal; 09:52:07 14 END LOOP; 09

使用10046 event跟踪session

ぐ巨炮叔叔 提交于 2019-12-07 00:48:27
10046event是 oracle 用于系统性能分析时的一个最重要的事件。当激活这个事件后,将通知oracle kernel追踪会话的相关即时信息,并写入到相应 trace 文件中。这些有用的信息主要包括 sql 是如何进行解析,绑定变量的使用情况,会话中发生的等 待事件等。10046event 可分成不同的级别(level),分别追踪记录不同程度的有用信息。对于这些不同的级别,应当注意的是向下兼容的,即高一级的trace信息包含低于此级 的所有信息。 10046event的追踪级别大致有: level 1:跟踪sql语句,包括解析、执行、提取、提交和回滚等。 level 4:包括变量的详细信息 level 8:包括等待事件 level 12:包括绑定变量与等待事件 其中,level 1相当于打开了sql_trace 10046event的启用和关闭: 前提条件:(先确保要event的会话环境符合条件) 1、必须确保timed_statistics为TRUE,这个参数可以在会话级上进行修改。 2、为了确保trace输出能够完整进行,还要调整此会话对trace文件大小的限制,一般将此限制取消,即将max_dump_file_size设置为UNLIMITED,或者设置为一个很大的阙值。 在满足了上述条件后,就可以启用10046event对会话进行后台跟踪了。