2

您好 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 上执行操作系统命令。有人可以为单行查询移植上述两种方法中的任何一种吗?

非常欢迎任何其他带有示例的建议。

非常感谢。

问候。

4

1 回答 1

1

在 CLR 支持出现之前,我曾经使用 xp_cmdshell。不幸的是,您的版本远离 CLR 支持 (SQL Server 2005) 和 system.io 命名空间。但是,您可以创建自己的扩展存储过程,该过程可以访问文件系统并创建目录。有关更多信息,请参见此处:http: //www.devarticles.com/c/a/SQL-Server/Extended-Stored-Procedures-Intro-And-10-Cool-Examples/

顺便说一下,xp_cmdshell 是一个扩展存储过程。

于 2012-04-08T01:45:57.100 回答