微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

循环通过服务器获取统计信息 (SSMS) 时找不到存储过程“sp_msforeachtable”

如何解决循环通过服务器获取统计信息 (SSMS) 时找不到存储过程“sp_msforeachtable”

我写这个是为了遍历服务器上的每个数据库,收集每个表的统计信息并将它们存储在一个临时表中。最终,我将把它整合到一个更永久的结构中,但现在我只是想让它工作。我的问题是,在 57 个数据库之后,我收到错误消息,指出它找不到存储过程 sp_msforeachtable。

我已验证该存储过程存在于服务器上和服务器级别的每个数据库中。

我已经通过将它添加到“名称不在”条件中来排除这个数据库,它只是移动到列表中的下一个并给出相同的错误。(我已经确认它存在于下一个数据库也是)。我实际上已经为接下来的 6 个数据库做了这个。

这导致我无法收集准确的信息。我是不是某个地方的资源用完了?

                    DECLARE @Database TABLE (dbname SYSNAME);
                    
                    IF OBJECT_ID('tempdb.dbo.#TableLvlSizes','U') IS NOT NULL 
                    BEGIN
                           PRINT 'dropping table'
                        DROP TABLE tempdb.dbo.#TableLvlSizes;
                    END    
                    
                    CREATE TABLE #TableLvlSizes (
                        TableName nvarchar(128),NumberOfRows varchar(50),Reservedspace varchar(50),TableDataSpace varchar(50),IndexSize varchar(50),unused varchar(50))
                    
                    DECLARE @dbname AS SYSNAME;
                    DECLARE @sql1 AS VARCHAR(MAX);
                    
                    SET @dbname = '';
                    
                    INSERT INTO @Database (dbname)
                    SELECT NAME
                    FROM sys.databases
                    where name not in ('tempdb')
                    ORDER BY NAME ASC;
                    
                    WHILE @dbname IS NOT NULL
                    BEGIN
                        SET @dbname = (
                                SELECT MIN(dbname)
                                FROM @Database
                                WHERE dbname > @dbname
                                );
                            print @dbname;
                            SET @sql1 =
                        'USE ' + @dbname + '; ' + '
                            Exec sp_msforeachtable
                            ''insert into #TableLvlSizes exec sp_spaceused [?]''
                        '
                        Exec (@sql1);
                    END

解决方法

既然您已经确认存储过程确实存在,我相信您的数据库区分大小写。因此,误差仍然是准确的。基本上,您使用的案例的存储过程不存在。实际的过程名称是 sp_MSforeachtable

在您的代码中,您使用了以下内容: 执行 sp_msforeachtable

如果您更改代码以使用存储过程的正确大小写为 sp_MSforeachtable,它应该可以工作:

SET @Sql1 =
            'USE ' + @DbName + '; ' + '
             Exec sp_MSforeachtable
             ''insert into #TableLvlSizes exec sp_spaceused [?]'''

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?