sqlserver(查看被锁进程)
-- ###### 查看被锁进程 ###### select 标志, 进程ID=spid,线程ID=kpid,块进程ID=blocked,数据库ID=dbid, 数据库名=db_name(dbid),用户ID=uid,用户名=loginame,累计CPU时间=cpu, 登陆时间=login_time,打开事务数=open_tran, 进程状态=status, 工作站名=hostname,应用程序名=program_name,工作站进程ID=hostprocess, 域名=nt_domain,网卡地址=net_address from( select 标志='死锁的进程', spid,kpid,a.blocked,dbid,uid,loginame,cpu,login_time,open_tran, status,hostname,program_name,hostprocess,nt_domain,net_address, s1 from master..sysprocesses a join ( select blocked from master..sysprocesses group by blocked )b union all select '|_牺牲品_>', spid,kpid,blocked,dbid,uid,loginame,cpu,login_time,open_tran, status,hostname,program_name,hostprocess,nt_domain,net_address, s1 )a order by s1,s2 -- 查询锁对象 , ) AS spid, ), DB_NAME (resource_database_id)) AS db_name, CASE WHEN resource_database_id = DB_ID () AND resource_type = 'OBJECT' THEN ), OBJECT_NAME (resource_associated_entity_id)) ELSE ), resource_associated_entity_id) END AS object, ), resource_type) AS resource_type, ), request_type) AS request_type, ), request_mode) AS mode, ), request_status) AS status FROM sys.dm_tran_locks WHERE resource_type = 'OBJECT' , DESC exec sp_lock EXEC sp_who active SELECT @@LOCK_TIMEOUT -- ###### 查first()记录 ###### -- 方法一 SELECT * FROM infu_master i WHERE i.infu_master_id = ( im.infu_master_id FROM infu_master im WHERE im.infu_status IN ('R', 'I', 'S') AND im.pati_id = i.pati_id ORDER BY im.infu_master_id ASC) -- 方法二 SELECT * FROM infu_master i WHERE i.infu_master_id IN (SELECT min (im.infu_master_id) AS infu_master_id FROM infu_master im WHERE im.infu_status IN ('R', 'I', 'S') GROUP BY im.pati_id) -- 方法三 SELECT * FROM (SELECT im.*, ROW_NUMBER () OVER (PARTITION BY im.pati_id ORDER BY im.infu_master_id) RN FROM infu_master im WHERE im.infu_status IN ('R', 'I', 'S')) t -- ###### 查引起死锁的操作 ###### USE master go DECLARE @spid INT --查询出死锁的SPID SELECT @spid = blocked FROM (SELECT * FROM sysprocesses ) a WHERE NOT EXISTS (SELECT * FROM (SELECT * FROM sysprocesses ) b WHERE a.blocked = spid) --输出引起死锁的操作 DBCC INPUTBUFFER (@spid) --exec sp_who2 use master go declare @spid int,@bl int DECLARE s_cur CURSOR FOR ,blocked ) a ) b where a.blocked=spid) OPEN s_cur FETCH NEXT FROM s_cur INTO @spid,@bl begin select '引起数据库死锁的是: )) + '进程号,其执行的SQL语法如下' else ))+ '被' + ' 进程号SPID:)) +'阻塞,其当前进程执行的SQL语法如下' DBCC INPUTBUFFER (@bl ) FETCH NEXT FROM s_cur INTO @spid,@bl end CLOSE s_cur DEALLOCATE s_cur -- ###### 查事务隔离级别 ###### SELECT session_id, (CASE transaction_isolation_level THEN 'ReadUncomitted' THEN 'ReadCommitted' THEN 'Repeatable' THEN 'Serializable' THEN 'Snapshot' END) [transaction_isolation_level] FROM sys.dm_exec_sessions WHERE session_id = @@SPID; DBCC USEROPTIONS select * FROM sys.dm_tran_locks; select * from sys.partitions; order by [type]; select * from sys.sysdatabases select * from sys.databases; select * from sys.schemas; -- 查被锁表并杀掉死锁进程 SELECT request_session_id spid, OBJECT_NAME (resource_associated_entity_id) tableName FROM sys.dm_tran_locks WHERE resource_type = 'OBJECT'; kill #{pid};
sqlserver(查看被锁进程)的更多相关文章
- SqlServer 查看死锁的进程
版权声明:本文为 走错路的程序员 原创文章,欢迎转载. https://blog.csdn.net/phker/article/details/78612974搞sqlsever 好多年, 从来没锁过 ...
- sqlserver查看被锁表、解锁
查看别锁表 select request_session_id spid,OBJECT_NAME(resource_associated_entity_id) tableName from sys.d ...
- SqlServer 查看被锁的表和解除被锁的表
查看被锁的表 1 2 select request_session_id spid,OBJECT_NAME(resource_associated_entity_id) tableName ...
- SqlServer 查看事务锁及执行语句
一.查看当前锁定的事务 ,) ,用户机器名称,) ,是否被锁住),blocked) ,数据库名称,),cmd 命令,waittype as 等待类型 ,last_batch 最后批处理时间,open_ ...
- Oracle查看有锁进程,删除锁
查看锁表进程SQL语句1: select sess.sid, sess.serial#, lo.oracle_username, lo.os_user_name, ao ...
- SqlServer 查看数据库锁,解除锁,此种情况一般常见都是由于事务所造成
检查数据库锁 SELECT request_session_id spid,OBJECT_NAME(resource_associated_entity_id)tableNameFROM sys.dm ...
- 知方可补不足~sqlserver中使用sp_who查看sql的进程
回到目录 在SQLSERVER中每个会话,即每个查询分析器窗口都会产生一个SQL进程,对于那些持续时间短的进程,它们转瞬即失,而对于持续时间比较长的,我们需要希望查看它的运行状态,就可以借助SQL提供 ...
- SqlServer查看锁表与解锁
某些情况下,sqlserver的表会被锁住,比如某个会话窗口有数据一直没提交,窗口又没关闭,这时表就会被锁住 其他任何连接查询表数据时都不会返回 这时需要手工杀掉产生死锁的会话ID,才能恢复正常 查看 ...
- mysql查看被锁住的表,正在进行的进程,已经杀掉进程的方法
mysql查看被锁的进程 //查看所有进程show processlist; //查询是否锁表show OPEN TABLES where In_use > 0; //查看被锁住的 SELECT ...
随机推荐
- laravel 远程一对多实例
/** * 关联楼宇推荐书关联表 * 远程一对一 */ public function buildingPanos() { return $this->hasManyThrough( 'App\ ...
- 栈(LIFO)
1 栈的定义 栈是限定在表尾进行插入和删除操作的线性表. 2 栈的特点 1)栈是特殊的线性表,线性表也具有前驱后继性: 2)栈的插入和删除操作只能在表尾即栈顶进行: 3)后进先出. 3 栈的实现及关键 ...
- Netty 5 io.netty.util.IllegalReferenceCountException 异常
异常信息 io.netty.util.IllegalReferenceCountException: refCnt: 0, decrement: 1 原因 handler 继承了 SimpleChan ...
- python基础之小数据池、代码块、编码和字节之间换算
一.代码块.if True: print(333) print(666) while 1: a = 1 b = 2 print(a+b) for i in '12324354': print(i) 虽 ...
- [UOJ422][集训队作业2018]小Z的礼物——轮廓线DP+min-max容斥
题目链接: [集训队作业2018]小Z的礼物 题目要求的就是最后一个喜欢的物品的期望得到时间. 根据$min-max$容斥可以知道$E(max(S))=\sum\limits_{T\subseteq ...
- 【ARC101F】Robots and Exits 树状数组
题目大意 有 \(n\) 个机器人和 \(m\) 个出口. 这 \(n\) 个机器人的初始位置是 \(a_1,a_2,\ldots,a_n\),这 \(m\) 个出口的位置是 \(b_1,b_2,\l ...
- mysql数据去重并排序使用distinct 和 order by 的问题
比如直接使用: SELECT distinct mobileFROM table_aWHERE code = 123ORDER BY a_ime desc 在本地mysql数据库没有错,在线上的数据库 ...
- 2018ICPC青岛现场赛 重现训练
先贴代码,以及简要题解. 和一个队友下午双排打了一下,队友光速签到,我签的J被嫌弃写得慢以及演员...然后我秒出了E了思路然而难以置信这么简单的思路当时才过了十几个,于是发现D.F不是太好做.最后交了 ...
- 欧拉筛法模板and 洛谷 P3383 【模板】线性筛素数(包括清北的一些方法)
题目描述 如题,给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内) 输入格式 第一行包含两个正整数N.M,分别表示查询的范围和查询的个数. 接下来M行每行包含一个不小于1 ...
- DP擎天
DP! 黄题: 洛谷P2101 命运石之门的选择 假装是DP(分治 + ST表) CF 982C Cut 'em all! 树形贪心 洛谷P1020 导弹拦截 单调队列水题 绿题: 洛谷P1594 护 ...