您好 Microsoft SQL Server 大师,
好吧,我有一个 Microsoft SQL Server 2000,如下所述:
Microsoft SQL Server 2000 - 8.00.2039 (Intel X86)
May 3 2005 23:18:38
Copyright (c) 1988-2003 Microsoft Corporation
Desktop Engine on Windows NT 5.2 (Build 3790: Service Pack 2)
我需要从这个 Microsoft SQL Server 执行操作系统命令,我使用下面的查询检查了我是否具有系统管理员权限,它返回“1”,这确认了我的权限。
SELECT IS_SRVROLEMEMBER('sysadmin', 'sa');
我尝试了传统的 xp_cmdshell 并没有发生任何事情,只是为了确保它正常工作,我尝试了著名的:
EXEC xp_cmdshell 'dir c:\'; EXEC master.dbo.xp_cmdshell 'dir c:\';
EXEC master..xp_cmdshell "dir c:\";
并且都没有返回任何内容,这让我相信 xp_cmdshell 不可用。我知道 xp_cmdshell 在 Microsoft SQL Server 2005 中默认禁用,但在 2000 中没有,无论如何,我尝试以相同的方式重新启用它,但它失败了。
我查看了互联网,发现这种方法可以为 Microsoft SQL Server 2000 重新启用 xp_cmdshell:
exec sp_addextendedproc 'xp_cmdshell', 'xplog70.dll'
exec sp_addextendedproc xp_cmdshell, 'C:\Program Files\Microsoft SQL Server\MSSQL\Binn\xplog70.dll'
但是,它仍然不起作用。我发现另一篇文章告诉有时管理员会删除这些文件,我认为这可能是我的情况,文章说如果它被删除,我可以执行“xp_msver”,在我的情况下它也不会返回任何内容。
参考: http: //support.microsoft.com/kb/891984
我还尝试了我在互联网上找到的这个查询,以查看 xp_cmdshell 是否存在并且它没有返回任何内容(但这可能是我奇怪的 SQL 客户端的限制,请参见下文)。
if exists (select * from dbo.sysobjects where id = object_id(N’[dbo].[ xp_cmdshell]‘) and OBJECTPROPERTY(id, N’IsExtendedProc’) = 1);
所以,我真的遇到了麻烦,我在 Google 进行了研究,发现了潜在的解决方案,例如 Job agent、SSIS 包、CLR 存储过程、sp_OACreate(和朋友)和 SQLCMD,但没有任何效果。也许我做错了,但我的另一个限制是我只能从一个跳转框(Linux)访问这个 Microsoft SQL Server 2000,它有一个非常奇怪的 sql-server 客户端,不接受多行查询,因此,我无法成功尝试以下潜在的解决方案:
1#工作代理
DECLARE @jobID uniqueidentifier, @cmd varchar(1000)
SET @cmd = 'netstat -na > c:\connections.txt'
EXEC msdb.dbo.sp_add_job @job_name = '_tmp_MakeDirectory', @enabled = 1, @start_step_id = 1, @owner_login_name='sa', @job_id = @jobID OUTPUT
EXEC msdb.dbo.sp_add_jobstep @job_id = @jobID, @step_name = 'Create Backup Folder', @step_id = 1, @subsystem = 'CMDEXEC', @command = @cmd
EXEC msdb.dbo.sp_add_jobserver @job_id = @jobID
EXEC msdb.dbo.sp_start_job @job_id = @jobID, @output_flag = 0
WAITFOR DELAY '000:00:05' -- Give the job a chance to complete
IF EXISTS (SELECT name FROM msdb.dbo.sysjobs WHERE name = '_tmp_MakeDirectory')
BEGIN
EXEC msdb.dbo.sp_delete_job @job_name = '_tmp_MakeDirectory'
END
2#SQLCMD
CREATE PROCEDURE SQLCMD_TEST
AS
!!MKDIR "netstat -na > c:\connections.txt"
:OUT "C:\TEST\test.TXT"
SELECT @@VERSION AS 'SERVER VERSION'
!!DIR
GO
SELECT @@SERVERNAME AS 'SERVER NAME'
GO
EXEC SQLCMD_TEST
不幸的是,我没有任何其他方法可以访问此 Microsoft SQL Server,我知道这不是最好的方法,但它就是这样,我无能为力。因此,我需要一个解决方案来在具有所有这些限制的 Microsoft SQL Server 2000 上执行操作系统命令。有人可以为单行查询移植上述两种方法中的任何一种吗?
非常欢迎任何其他带有示例的建议。
非常感谢。
问候。