知方可补不足~sqlserver中使用sp_who查看sql的进程

回到目录

在SQLSERVER中每个会话,即每个查询分析器窗口都会产生一个SQL进程,对于那些持续时间短的进程,它们转瞬即失,而对于持续时间比较长的,我们需要希望查看它的运行状态,就可以借助SQL提供的sp_who命令,下面是对它的具体介绍,主要选自MSDN.

sp_who [ [ @loginame = ] 'login' | session ID | 'ACTIVE' ]
你可以在sp_who后面加你的SPID号(sessionID),登陆名,线程状态等


下面对status执行状态作一个简单的说明,选自MSDN

background会话正在运行一个后台任务,例如死锁检测。

rollback: 会话具有正在处理的事务回滚。

pending: 会话正在等待工作线程变为可用。

runnable: 会话的任务在等待获取时间量程时位于计划程序的可运行队列中。

spinloop: 会话的任务正在等待调节锁变为可用。

suspended: 会话正在等待事件(如 I/O)完成。

注意:如果你的代码处理数据比较大,SQL会创建子线程进行并行处理,子线程的标示为ecid。

别外,如果希望查看SQL进程的详细信息,可以使用下面代码

SELECT * FROM sys.sysprocesses

查看被锁住的对象,可以使用下面代码

SELECT * FROM sys.syslockinfo

 如果希望查看指定会话(SQL进程)的语句(从客户端发过来的SQL语句),可以使用下面语句

dbcc inputbuffer(Session_ID)

如果希望查看正在被阻塞的语句(sysprocesses的blocked),可以使用下面语句

dbcc inputbuffer(Blocked)

 

回到目录

转载于:https://www.cnblogs.com/lori/p/3303550.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值