检查Oracle 中死事务的语句

SQL> SELECT KTUXEUSN, KTUXESLT, KTUXESQN, /* Transaction ID */
  2  KTUXESTA Status,    KTUXECFL Flags ,KTUXESIZ
  3  FROM x$ktuxe
  4  WHERE ktuxesta!='INACTIVE';

  KTUXEUSN   KTUXESLT   KTUXESQN STATUS           FLAGS                      KTUXESIZ
---------- ---------- ---------- ---------------- ------------------------ ----------
        13          5      47447 ACTIVE           DEAD                        2819919
        39          0        502 ACTIVE           NONE                              1
        43         45        480 ACTIVE           NONE                              0
SQL> /

  KTUXEUSN   KTUXESLT   KTUXESQN STATUS           FLAGS                      KTUXESIZ
---------- ---------- ---------- ---------------- ------------------------ ----------
        13          5      47447 ACTIVE           DEAD                        2819919<----该值没减小。
        39          0        502 ACTIVE           NONE                              1
        43         45        480 ACTIVE           NONE                              0

查询v$px_session和v$fast_start_servers,显示非常多并行进程在rollback,依据以往的project经验:

于是改为

SQL>alter system set fast_start_parallel_rollback=false scope=both;

之后,再次执行

SQL> SELECT KTUXEUSN, KTUXESLT, KTUXESQN,/* Transaction ID */
 2  KTUXESTA Status,    KTUXECFL Flags ,KTUXESIZ
 3  FROM x$ktuxe
 4  WHERE ktuxesta!='INACTIVE';
 KTUXEUSN   KTUXESLT   KTUXESQN STATUS           FLAGS                      KTUXESIZ
---------- ---------- -------------------------- ------------------------ ----------
       13          5      47447 ACTIVE           DEAD                        2033516
       35         29        502 ACTIVE           NONE                              1

SQL> /

 KTUXEUSN   KTUXESLT   KTUXESQN STATUS           FLAGS                      KTUXESIZ
---------- ---------- -------------------------- ------------------------ ----------
       13          5      47447 ACTIVE           DEAD                        2033433<---该值不断变小。
       35         29        502 ACTIVE           NONE                              1

使用例如以下脚本查看回滚完成的估计时间(以天为单位):

SQL> set serveroutput on
SQL> declare
 2   l_start number;
 3   l_end number;
 4   begin
 5   select ktuxesiz into l_startfrom x$ktuxe where KTUXEUSN=13 and KTUXESLT=5;
 6   dbms_lock.sleep(60);
 7   select ktuxesiz into l_endfrom x$ktuxe where KTUXEUSN=13 and KTUXESLT=5;
 8   dbms_output.put_line('time estDay:'|| round(l_end/(l_start -l_end)/60/24,2));
  9   end;
 10   /
time est Day:.21

24*0.21=5.04小时。即:估计5.04小时后回滚完成。

另外注意:在其它环境使用时,请注意替换KTUXEUSN=13和KTUXESLT=5

检查Oracle 中死事务的语句,布布扣,bubuko.com

时间: 2024-10-25 21:47:00

检查Oracle 中死事务的语句的相关文章

4.事务提交过程,事务基本概念,Oracle中的事务生命周期,保存点savepoint,数据库的隔离级别

 事务提交过程 事务 基本概念 概念:一个或者多个DML语言组成 特点:要么都成功,要么都失败 事务的隔离性:多个客户端同时操作数据库的时候,要隔离它们的操作, 否则出现:脏读  不可重复读  幻读 Oracle默认情况下,事务是打开的 commit案例: SQL> create table t1(tid int,tname varchar2(20)); 表已创建. SQL> select * from tab; TNAME                          TABTYPE

在oracle中跟踪会话执行语句的几种方法

生成sql trace可以有以下几种方式: 1.参数设置:非常传统的方法. 系统级别: 参数文件中指定: sql_trace=true 或 SQL> alter system set sql_trace=true; 注意:系统级别启用sql_trace,会产生大量trace文件,很容易耗尽磁盘空间,因此一般设置会话级别,并且及时关闭. 会话级别: SQL> alter session set sql_trace=true; SQL> 执行sql SQL> alter session

oracle中的事务

数据库事务有严格的定义,它必须满足4个特性:原子性(Atomic):表示组成一个事务的多个数据库操作是一个不可分割的原子单元只有所有的操作执行成功,整个事务才能提交,事务中任何一个数据库操作失败,己经执行的任何操作都必须撤销,让数据主加返回到初状态.一致性(Consistency):事务操作成功后,数据所处的状态和它的业务规则是一致的,即数据不会被被破坏.如从A账户转账100元到B账户,不管操作成功与否,A和B的存款总额不变的.隔离性(Isolation):在并发数据操作时,不同的事务拥有各自的

【Oracle】浅析Oracle中的事务

1. 什么是事务 在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么都成功执行,完成整个工作单元操作,要么一个也不执行. 如:网上转帐就是典型的要用事务来处理,用以保证数据的一致性. 2. 事务特性 SQL92标准定义了数据库事务的四个特点: 原子性(Atomicity):一个事务里面所有包含的SQL语句是一个执行整体,不可分割,要么都做,要么都不做. 一致性(Consistency):事务开始时,数据库中的数

Oracle 浅析Oracle中的事务

1. 什么是事务 在数据库中事务是工作的逻辑单元,一个事务是由一个或多个完成一组的相关行为的SQL语句组成,通过事务机制确保这一组SQL语句所作的操作要么都成功执行,完成整个工作单元操作,要么一个也不执行. 如:网上转帐就是典型的要用事务来处理,用以保证数据的一致性. 2. 事务特性 SQL92标准定义了数据库事务的四个特点: 原子性(Atomicity):一个事务里面所有包含的SQL语句是一个执行整体,不可分割,要么都做,要么都不做. 一致性(Consistency):事务开始时,数据库中的数

Oracle中的一些查询语句及其执行顺序

查询条件: 1)LIKE:模糊查询,需要借助两个通配符,%:表示0到多个字符:_:标识单个字符. 2)IN(list):用来取出符合列表范围中的数据. 3)NOT IN(list): 取出不符合此列表中的数据记录. 4)BETWEEN-AND-:用来查询符合某个值域范围条件的数据,最常见的是使用在数字类型的数据范围上,但对字符类型和日期类型数据也同样适用.for example:    SELECT ename, sal FROM emp WHERE sal BETWEEN 1500 AND 3

Oracle中的事务(1)

数据库事务(Database Transaction) ,是指作为单个逻辑工作单元执行的一系列操作. 事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源.通过将一组相关操作组合为一个要么全部成功要么全部失败的单元,可以简化错误恢复并使应用程序更加可靠.---[来自百度百科] 事务的四大特性: 原子性(atomicity) 事务必须是原子工作单元:对于其数据修改,要么全都执行,要么全都不执行. 一致性(consistency) 事务在完成时,必须使所有的数据都保持

Oracle中的一连接语句

首先构建场景 相应表中数据如下: 1 SELECT * FROM EMPLOYEE: 1 SELECT * FROM DEPTINFO; 1 SELECT E.EMPNAME, D.DEPNAME 2 FROM EMPLOYEE E, DEPTINFO D 3 WHERE E.DEPTID = D.DEPID 4 ORDER BY DEPNAME; 1 SELECT E.EMPNAME, D.DEPNAME 2 FROM EMPLOYEE E 3 JOIN DEPTINFO D 4 ON E.D

Oracle中DDL语句对事务的影响

 1.Oracle中DDL语句对事务的影响 在Oracle中,执行DDL语句(如Create Table.Create View等)时,会在执行之前自动发出一个Commit命令,并在随后发出一个Commit或者Rollback命令,也就是说,DDL会象如下伪码一样执行: Commit;DDL_Statement; If (Error) then Rollback; Else Commit;End if; 我们通过分析下面例子来看Oracle中,DDL语句对事务的影响: Insert into