查询数据库锁的SQL

SELECT bs.username "Blocking User", bs.username "DB User",
ws.username "Waiting User", bs.SID "SID", ws.SID "WSID",
bs.serial# "Serial#", bs.sql_address "address",
sq.sql_fulltext "sql",
bs.sql_hash_value "Sql hash", bs.program "Blocking App",
ws.program "Waiting App", bs.machine "Blocking Machine",
ws.machine "Waiting Machine", bs.osuser "Blocking OS User",
ws.osuser "Waiting OS User", bs.serial# "Serial#",
ws.serial# "WSerial#",
DECODE (wk.TYPE,
‘MR‘, ‘Media Recovery‘,
‘RT‘, ‘Redo Thread‘,
‘UN‘, ‘USER Name‘,
‘TX‘, ‘Transaction‘,
‘TM‘, ‘DML‘,
‘UL‘, ‘PL/SQL USER LOCK‘,
‘DX‘, ‘Distributed Xaction‘,
‘CF‘, ‘Control FILE‘,
‘IS‘, ‘Instance State‘,
‘FS‘, ‘FILE SET‘,
‘IR‘, ‘Instance Recovery‘,
‘ST‘, ‘Disk SPACE Transaction‘,
‘TS‘, ‘Temp Segment‘,
‘IV‘, ‘Library Cache Invalidation‘,
‘LS‘, ‘LOG START OR Switch‘,
‘RW‘, ‘ROW Wait‘,
‘SQ‘, ‘Sequence Number‘,
‘TE‘, ‘Extend TABLE‘,
‘TT‘, ‘Temp TABLE‘,
wk.TYPE
) lock_type,
DECODE (hk.lmode,
0, ‘None‘,
1, ‘NULL‘,
2, ‘ROW-S (SS)‘,
3, ‘ROW-X (SX)‘,
4, ‘SHARE‘,
5, ‘S/ROW-X (SSX)‘,
6, ‘EXCLUSIVE‘,
TO_CHAR (hk.lmode)
) mode_held,
DECODE (wk.request,
0, ‘None‘,
1, ‘NULL‘,
2, ‘ROW-S (SS)‘,
3, ‘ROW-X (SX)‘,
4, ‘SHARE‘,
5, ‘S/ROW-X (SSX)‘,
6, ‘EXCLUSIVE‘,
TO_CHAR (wk.request)
) mode_requested,
TO_CHAR (hk.id1) lock_id1, TO_CHAR (hk.id2) lock_id2,
DECODE
(hk.BLOCK,
0, ‘NOT Blocking‘, /**//* Not blocking any other processes */
1, ‘Blocking‘, /**//* This lock blocks other processes */
2, ‘Global‘, /**//* This lock is global, so we can‘t tell */
TO_CHAR (hk.BLOCK)
) blocking_others
FROM v$lock hk, v$session bs, v$lock wk, v$session ws,v$sql sq
WHERE hk.BLOCK = 1
AND hk.lmode != 0
AND hk.lmode != 1
AND wk.request != 0
AND wk.TYPE(+) = hk.TYPE
AND wk.id1(+) = hk.id1
AND wk.id2(+) = hk.id2
AND hk.SID = bs.SID(+)
AND wk.SID = ws.SID(+)
AND (bs.username IS NOT NULL)
AND (bs.username <> ‘SYSTEM‘)
AND (bs.username <> ‘SYS‘)
and ws.SQL_ADDRESS=sq.address
and ws.SQL_HASH_VALUE=sq.hash_value

时间: 2024-08-03 06:50:31

查询数据库锁的SQL的相关文章

查询数据库锁

查询数据库锁的根源: SELECT a.spid,a.blocked,a.waitresource,a.dbid,a.hostname,a.program_name,c.text AS a_sql ,b.hostname AS b_hostName,b.program_name AS b_programName,d.text AS b_sql FROM sys.sysprocesses a INNER JOIN sys.sysprocesses b ON b.spid=a.blocked CRO

查询数据库表大小sql

SELECT a.name, b.rowsFROM sysobjects AS a INNER JOIN sysindexes AS b ON a.id = b.idWHERE (a.type = 'u') AND (b.indid IN (0, 1))ORDER BY b.rows DESC

一例胜千言,详谈SQL Sever数据库锁

1 前言 数据库大并发操作要考虑死锁和锁的性能问题.看到网上大多语焉不详(尤其更新锁),所以这里做个简明解释,为下面描述方便,这里用T1代表一个数据库执行请求,T2代表另一个请求,也可以理解为T1为一个线程,T2 为另一个线程.T3,T4以此类推.下面以SQL Server(2005)为例. 2 锁的种类 共享锁(Shared lock). 例1: ---------------------------------------- T1: select * from table (请想象它需要执行

ORACLE查询数据库的锁表情况

  查询数据库的锁表情况语句如下: SELECT p.spid,a.serial#, c.object_name,b.session_id,b.oracle_username,b.os_user_name FROM v$process p,v$session a, v$locked_object b,all_objects c WHERE p.addr=a.paddr AND a.process=b.process AND c.object_id=b.object_id 如果表因为某些情况出现死

SQL查询数据库是否存在

在实际工作中会遇到通过SQL查询数据库是否存在的情况,下面一些语句可以提供一些帮助,本文的语句是在SQL08R2中测试的 1,查询当前数据库服务器所有数据库 select *  From master.dbo.sysdatabases 2,查询数据库是否存在 select count(*) From master.dbo.sysdatabases where name='数据库名' 3,查询某数据库中所有用户表 select * from sysobjects where xtype='U' ‘

sql server 查询数据库所有的表名+字段

原文:sql server 查询数据库所有的表名+字段 SELECT * FROM INFORMATION_SCHEMA.columns WHERE TABLE_NAME='Account' SELECT    (case when a.colorder=1 then d.name else '' end) as 表名,--如果表名相同就返回空       a.colorder as 字段序号,       a.name as 字段名,       (case when COLUMNPROPER

SQL 中怎么查询数据库中具有的表、存储过程、试图数目、总触发器数、作业数

用户表:select count(*) 总表数 from sysobjects where xtype='u' 刚才那个是用户表,下面这个是系统表加用户表: select count(*) 总表数 from sysobject s where xtype in('u','s') 总视图数:select count(*) 总视图数 from sysobjects where xtype='v' 总存储过程数:select count(*) 总存储过程数 from sysobjects where

(转)SQL server 2005查询数据库表的数量和表的数据量

本文转载自:http://hi.baidu.com/ajyajyajy/item/4e2a7f4dc83393d2c1a592c1 use DBNAMEgoselect * from sysobjects where xtype='U'; --这是查询所有表的信息select count(*) from sysobjects where xtype='U' --这是查询表的数量 ‍select a.name, b.rows from sysobjects a with(nolock) join

SQL Server查询数据库空间分配情况、数据库备份信息

查询数据库空间分配情况: 1 use master 2 go 3 create procedure dbo.proc_getdbspaceused 4 as 5 begin 6 set nocount on 7 create table #dbsize( 8 database_id int 9 ,database_name nvarchar(1024) 10 ,size_kb bigint 11 ,space_available_kb bigint 12 ,reserved_kb bigint