如何在sql-server 2008中显示哪个用户连接到Database X?

时间:2011-04-21 11:05:02

标签: sql-server-2008

如何在sql-server 2008中显示哪个用户连接到Database X?

我的sql-server 2008中有很多数据库,我只需要显示连接并在数据库X上工作的用户

提前致谢

3 个答案:

答案 0 :(得分:1)

答案 1 :(得分:0)

您还可以使用Ctrl + Alt + A打开资源监视器,并查看哪个用户连接到您的数据库X

答案 2 :(得分:0)

@ gabriel-adams在this类似问题上提供了一个很好的脚本。如果您喜欢我并在Google搜索中漫游,这可能会为您节省几次点击。

SELECT
    SessionId           = ses.session_id
    ,[Database]    = DB_Name(er.database_id)
    ,[Login]            = ses.login_name
    ,Host               = ses.host_name
    ,StartTime          = er.start_time
    ,ClientAddress      = con.client_net_address
    ,SQLStatement       = st.text
FROM sys.dm_exec_requests er
OUTER APPLY sys.dm_exec_sql_text(er.sql_handle) st
LEFT JOIN sys.dm_exec_sessions ses ON ses.session_id = er.session_id
LEFT JOIN sys.dm_exec_connections con ON con.session_id = ses.session_id
WHERE ses.is_user_process = 0x1
AND ses.session_id != @@SPID
ORDER BY
    ses.session_id