关闭

如何将 DBCC INDEXDEFRAG 执行的结果插入到表中

标签: sqlserverwindowsnullgo
3763人阅读 评论(0) 收藏 举报
分类:

如何将 DBCC INDEXDEFRAG 执行的结果插入到表中

欲将 DBCC INDEXDEFRAG 执行的结果插入到表中,收到如下错误信息"用户事务下无法对dbcc indexdefrag的结果操作"

-- 获取数据
DECLARE @err int,@src varchar(255),@desc varchar(255)
DECLARE @obj int,@str varchar(1000)
-- 使用 Windows 身份登录
SET @str='Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=master;Data Source='

-- 使用 SQL Server 身份登录则用此字符串,注意设置用户名和密码
-- SET @str='Provider=SQLOLEDB.1;Persist Security Info=False;Initial Catalog=master;Data Source=;User ID=sa;Password='

-- 创建对象
EXEC @err=sp_oacreate 'adodb.recordset',@obj OUT
IF @err<>0 GOTO lberr

-- 获取需要的数据
EXEC @err=sp_oamethod @obj,'open',null,'DBCC INDEXDEFRAG (Northwind, Orders, CustomersOrders)',@str
IF @err<>0 GOTO lberr

CREATE TABLE #(Column0 int,Column1 int,Column2 int)
INSERT # EXEC @err=sp_oamethod @obj,'getrows'
IF @err<>0 GOTO lberr

EXEC @err=sp_oadestroy @obj
RETURN

lberr:
    EXEC sp_oageterrorinfo 0,@src OUT,@desc OUT
    SELECT CAST(@err as varbinary(4)) as 错误号,
        @src as 错误源,@desc as 错误描述
GO

-- 显示结果
SELECT * FROM #
DROP TABLE #

     原帖地址

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:1279228次
    • 积分:14875
    • 等级:
    • 排名:第816名
    • 原创:178篇
    • 转载:9篇
    • 译文:0篇
    • 评论:881条
    最新评论