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 ...
随机推荐
- 【zabbix教程系列】二、zabbix特点
一.度量收集 从任何设备,系统,应用上收集指标,收集指标的方法有: 多平台zabbix代理 SNMP and IPMI 代理 无代理监控用户服务 自定义方法 计算和聚合 用户端web监控 二.问题发 ...
- JAVA并发包学习
1)CyclicBarrier一个同步辅助类,允许一组线程相互等待,直到这组线程都到达某个公共屏障点.该barrier在释放等待线程后可以重用,因此称为循环的barrier 2)CountDownLa ...
- 这才是你想要的 Python 可视化神器
Plotly Express 是一个新的高级 Python 可视化库:它是 Plotly.py 的高级封装,它为复杂的图表提供了一个简单的语法. 受 Seaborn 和 ggplot2 的启发,它专门 ...
- LODOP中ADD_PRINT_TABLE、HTM、HTML表格自动分页测试
LODOP中超文本超过打印项高度会自动分页,那么对于超大行,该行处在分页高度位置会怎样呢?本文用来测试一下三个语句对html中table中超大行在分页高度位置的处理. 测试结果:ADD_PRINT_T ...
- codeforces645B
Mischievous Mess Makers CodeForces - 645B It is a balmy spring afternoon, and Farmer John's n cows a ...
- HBase轻松入门之HBase架构图解析
2018-12-13 2018-12-20 本篇文章旨在针对初学者以我本人现阶段所掌握的知识就HBase的架构图中各模块作一个概念科普.不对文章内容的“绝对.完全正确性”负责. 1.开胃小菜 关于HB ...
- [九省联考2018]秘密袭击coat
[九省联考2018]秘密袭击coat 研究半天题解啊... 全网几乎唯一的官方做法的题解:链接 别的都是暴力.... 要是n=3333暴力就完了. 一.问题转化 每个联通块第k大的数,直观统计的话,会 ...
- vue---mixins的用法
相信大家都用过less.sass等预编译器.它们中也有mixins,用法也很简单,例如Less中: .box{ border:1px solid red; padding:10px; } .mixin ...
- python dic字典使用
#!/usr/bin/env python -*-''' 字典的基本组成及用法: dict={key:value} dict[key]=value 字典是无序的. key值是唯一属性,一对一,几个ke ...
- 第四届CCCC团体程序设计天梯赛 后记
一不小心又翻车了,第二次痛失200分 1.开局7分钟A了L2-3,一看榜已经有七个大兄弟排在前面了,翻车 * 1 2.把L1-3 A了18分,留了两分准备抢顽强拼搏奖,最后五秒钟把题过了,万万没想到还 ...