Get windows user login name from sql server(从sql server获取windows用户登录名)
问题描述
我的数据库配置为使用登录名 sa 的 SQL 服务器身份验证.现在我想知道用户的Windows 登录用户名是什么.SA 将在那里为每个人服务.我能够获得计算机IP地址和计算机名,但我迫切需要用户的Windows登录用户名.我的网络是使用活动目录设置的.
My database is configured to use SQL server authentication with login name sa. Now I would like to know what is the user's Windows login user name. SA will be there for everybody. I was able to get the computer IP address and Computer name, but I desperately need the user's Windows login user name. My network is setup using active directory btw.
set @UserComputerIP = CONVERT(varchar(20),CONNECTIONPROPERTY('client_net_address'))
set @UserComputerName = CONVERT(varchar(20),HOST_NAME())
任何帮助将不胜感激.(Ps. 不,我无法在 SQL Server 中切换到 Windows 身份验证)
Any help would be appreciated. (Ps. No i cannot switch to Windows Authentication in SQL Server)
推荐答案
如果您不使用 Windows 身份验证,我不确定您是否可以获得域用户名.
I'm not sure if you can obtain the domain user name if you're not using Windows Authentication.
我所知道的最详细的信息是系统表/视图,如果您使用 SQL 登录名连接,这些信息不会显示 NT 用户名.即使服务器处于混合身份验证模式.
The most detailed info that I know of are the system tables/views, and those don't show the NT user name if you connected using a SQL login. Even if the server is in mixed authentication mode.
在 SQL Server 2008 之前的版本上:
On pre-SQL Server 2008:
select nt_username from master.sys.sysprocesses where spid = @@spid
从 SQL Server 2008 开始:
From SQL Server 2008 on:
select nt_user_name from sys.dm_exec_sessions where session_id = @@spid
如果您使用 SQL 身份验证连接,两者都会显示一个空列.
Both will show an empty column if you connected using SQL authentication.
这篇关于从sql server获取windows用户登录名的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:从sql server获取windows用户登录名
基础教程推荐
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- 带更新的 sqlite CTE 2022-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
