sqlserver 下面执行dos 命令

- SYSTEM 帐户没有访问网络资源的能力,因此无法使用 NET USE 建立连接。
-- 针对 LZ 的问题,有一种方法是建立 XP_CMDSHELL 的代理帐户,通过代理帐户连接远程共享。
-- 非 SYSADMIN 服务器角色的登陆帐户都以代理帐户的身份运行 WINDOWS 程序,而 SYSADMIN 成员都以 SQL SERVER 服务帐户(SYSTEM)的身份运行程序。

-- 创建登陆帐户
USE MASTER
GO
CREATE LOGIN test WITH PASSWORD='123';
GO
-- 在 MASTER 数据库下创建用户帐户
CREATE USER test FROM LOGIN test;
GO
-- 授予该用户帐户执行 xp_cmdshell 的权限
GRANT execute on xp_cmdshell TO test;
GO

-- 访问共享
exec as login='test';
-- 也可以在系统上直接建立映射
exec xp_cmdshell 'net use z: \\11.168.255.12\i$ password /user:administrator';
-- 直接通过映射盘符访问
exec xp_cmdshell 'dir z:';
revert;

-- 清理
revoke execute on xp_cmdshell from [test];
go
drop user [test];
go
drop login [test];
go

-- 上面的语句适用于 SQL Server 2005

你可能感兴趣的:(sqlserver)