zjcxc(邹建)的Blog - SQL Server

引用或者转载本BLOG的文章请注明原作者和出处,并保留原文章中的版权信息。谢谢!...

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

如何将 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 #

     原帖地址

阅读更多
个人分类: BUG与疑难问题
上一篇在全文索引建立的目录不存在情况下删除全文索引
下一篇在 SQL Server 2005 中查询表结构及索引
想对作者说点什么? 我来说一句

将sql查询结果保存到数据表

2012年08月26日 802B 下载

必须知道的SQL基础 知识 技巧

2010年04月09日 4KB 下载

基本SQL语句大全-收缩数据库

2009年04月21日 2KB 下载

将DOS中的结果输出到变量中

2010年01月11日 2KB 下载

sql行列互转

2017年12月27日 7KB 下载

dbcc语句结果

2011年11月24日 61KB 下载

没有更多推荐了,返回首页

关闭
关闭