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

时间:2010-10-21 21:04:30

标签: sql sql-server ms-access vba

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

4 个答案:

答案 0 :(得分:15)

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

sp_who2

修改

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

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

答案 1 :(得分:5)

对于SQL Server,您可以尝试

SELECT * 
FROM sys.dm_exec_sessions

将列出所有未结会话

答案 2 :(得分:2)

这完全取决于如何在访问数据库中实现SQL Server的安全性和访问权限

如果它为sql后端的所有用户使用单个SQL Server登录(这是常见的),则无法知道。

答案 3 :(得分:1)

1)您,开发人员必须具有SQL Server上的VIEW SERVER STATE权限才能查看SQL Server实例上的所有正在执行的会话。否则,您将只看到当前会话最简单的方法是使用您的sysadmin凭据打开连接(即使用sqlcmd或Management Studio)并发出以下语句:

GRANT VIEW SERVER STATE TO(您的网络用户ID)

2)访问似乎在五分钟或十分钟不活动后与SQL Server断开连接。我还没有时间进行详细搜索,并找出可以覆盖此设置的设置。

3)使用SQL Server工具的开发人员可能会连接到master数据库,即使他们正在查看数据库中的对象。