代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
MSSQL
】
简单解决阻塞方案
作者:
Dezai.CN
/ 发布于
2013/3/26
/
1027
select * from master .dbo.sysprocesses where blocked>0---查看阻塞---blocked 指被阻塞或锁定的SPID go dbcc inputbuffer(5)--查看具体是那个SQL阻塞5指SPID go Sp_lock--- 找出spid=5 --objid 被锁定或阻塞的对象--dbid 被阻塞或锁定的对象所在的DB go Select db_name(@dbid)---找到数据库 go select object_name(@objid)---找到表 go select @@LOCK_TIMEOUT -- -1 无限期等待 0 发生锁定或阻塞直接抛出错误。 --查看那个进程ID阻塞了哪几个进程ID --session_id被阻塞者、blocking_session_id阻塞者 SELECT blocking_session_id, wait_duration_ms, session_id,* FROM sys.dm_os_waiting_tasks where blocking_session_id is not null --查看整个数据库的锁定和阻塞详细信息: SELECT * FROM sys.dm_tran_locks EXEC sp_lock 解决方法: 如果是更新,则改为不再实时对tabA表进行update操作,而是每次访问都先insert一条记录到一个中间表中,然后再用一个作业, 每隔几分钟定时更新书目标表中的数据。 ---检测数据阻塞语句 create procedure pr_check_blocked_SQL ---ZHAOWENZHONG ---检测数据阻塞语句 AS SET NOCOUNT ON IF EXISTS(SELECT 1 FROM MASTER..SYSPROCESSES WHERE BLOCKED>0) BEGIN SELECT '以下SQL语句是引起阻塞的源' select distinct sp.spid '进程ID',sp.status '进程ID的状态', sp.blocked '分块进程的进程ID',sp.hostname '工作站名', sp.uid '执行者',sp.dbid 'DB', sp.program_name'应用程序名', sp.cmd '目前正在执行的命令',sp.cpu 'CPU时间', sp.physical_io 'IO', sp.loginame '登录名', st.text '执行SQL语句' from master..sysprocesses as sp cross apply sys.dm_exec_sql_text(sp.sql_handle)as st where sp.blocked=0 and sp.spid in(select blocked from master..sysprocesses ) --被阻塞的SQL SELECT '以下是被阻塞的SQL语句' select distinct sp.spid '进程ID',sp.status '进程ID的状态', sp.blocked '分块进程的进程ID',sp.hostname '工作站名', sp.uid '执行者',sp.dbid 'DB', sp.program_name'应用程序名', sp.cmd '目前正在执行的命令',sp.cpu 'CPU时间', sp.physical_io 'IO', sp.loginame '登录名', st.text '执行SQL语句' from master..sysprocesses as sp cross apply sys.dm_exec_sql_text(sp.sql_handle)as st where sp.blocked<>0 END
试试其它关键字
阻塞
同语言下
.
SQL查询 多列合并成一行用逗号隔开
.
查看存储过程修改时间,最近执行时间
.
设置手动批量删除数据库相关进程
.
获取某个表中特定字段的所有字符串形式
.
SQL 如何去除重复的字符串
.
怎么去掉一个字段中的重复数据
.
String 去除空格 回车 换行 水平制表符
.
SQL查询和替换含有回车,空格,TAB
.
SQL SERVER 查询每日新增用户数量、次留数量
.
判断两个字符串是否存在相同的内容
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
Dezai.CN
贡献的其它代码
(
4037
)
.
多线程Socket服务器模块
.
生成随机密码
.
清除浮动样式
.
弹出窗口居中
.
抓取url的函数
.
使用base HTTP验证
.
div模拟iframe嵌入效果
.
通过header转向的方法
.
Session操作类
.
执行sqlite输入插入操作后获得自动编号的ID
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3