SQLSERVER数据库连接

1. 如果要查询是否连接没有释放引起的,   你可以用查询分析器连接到你的数据库服务器,   执行下面的代码:  
  select   *   from   master.dbo.sysprocesses  
  where   spid>50  
  and   waittype   =   0x0000  
  and   waittime   =   0  
  and   status   =   'sleeping'  
  and   last_batch   <   dateadd(minute,   -10,   getdate())  
  and   login_time   <   dateadd(minute,   -10,   getdate())  
    如果这样的进程很多,   则说明连接确实有很多连接没有释放(上面的查询查询出已经超过10分钟都没有做任何动作的连接)  
  2. 如果确实是连接没有释放的问题,   你可以硬行释放连接,   不一定要改程序.   在sql   server中,   创建一个job,   每10分钟一次,   执行下面的代码来定时检查并释放掉空连接就可以了:  
  declare   hcforeach   cursor   global  
  for  
  select   'kill   '   +   rtrim(spid)   from   master.dbo.sysprocesses  
  where   spid>50  
  and   waittype   =   0x0000  
  and   waittime   =   0  
  and   status   =   'sleeping'  
  and   last_batch   <   dateadd(minute,   -60,   getdate())  
  and   login_time   <   dateadd(minute,   -60,   getdate())  
  exec   sp_msforeach_worker   '?'

posted on 2011-07-18 09:02  Peter Zhang  阅读(621)  评论(0编辑  收藏  举报