sp_who查看sql的进程
2015-01-05 14:49
375 查看
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)
相关文章推荐
- 知方可补不足~sqlserver中使用sp_who查看sql的进程
- sp_block查看数据库进程状态(是否阻塞,执行SQL等),可替代sp_who
- SQL2005查看死锁存储过程sp_who_lock
- 查看ms sqlserver数据库是否有进程死锁
- SQL 死锁进程查看与处理
- Transact-SQL参考:sp_who
- Oracle数据库查看一个进程是如何执行相关的实际SQL语句
- 查看锁表进程SQL语句
- 在SQL2000、SQL2005查看阻塞进程的SQL脚本
- 如何查看SQLSERVER的版本信息和SP补丁信息(适用于SQL2005,2008)
- 在SQL2000、SQL2005查看阻塞进程的SQL脚本
- oracle 中--怎么查看当前表空间在作什么操作?--查锁,死锁,当前执行时间长的Sql语句,没提交的事务,对象为哪些进程所用
- Oracle查看进程执行sql
- SQL 死锁进程查看与处理
- SQL 死锁进程查看与处理
- Transact-SQL参考:sp_who
- SQL 死锁进程查看与处理
- sql2005 查看数据库或表大小的系统存储过程 sp_spaceused
- oracle 中--怎么查看当前表空间在作什么操作?--查锁,死锁,当前执行时间长的Sql语句,没提交的事务,对象为哪些进程所用
- Transact-SQL参考:sp_who、sp_who2和sp_who3