sql-server:我怎么知道谁在我的数据库中?

l--*_*''' 5 sql sql-server ms-access vba

我有一个访问前端和SQL Server后端.我想知道哪些用户当前正在使用该数据库.这可以使用access或sql-server吗?

Gab*_*ams 21

在SQL Server中,您可以运行此存储过程:

sp_who2
Run Code Online (Sandbox Code Playgroud)

编辑:

如果要查看在任何给定时间使用服务器的用户,可以使用此查询.这将允许您随意进一步过滤.

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
Run Code Online (Sandbox Code Playgroud)


mca*_*ral 5

对于SQL Server,您可以尝试

SELECT * 
FROM sys.dm_exec_sessions
Run Code Online (Sandbox Code Playgroud)

这将列出所有打开的会话