我编写此代码是为了循环访问服务器上的每个数据库,收集每个表的统计信息并将它们存储在临时表中。最终,我会将其集成到一个更永久的结构中,但现在我只是想让它发挥作用。我的问题是,在 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 …Run Code Online (Sandbox Code Playgroud)