如果数据库位于同一 SQL-Server 实例上,则可以使用 sp_msforeachdb 来迭代数据库
CREATE TABLE #tmp (DatabaseName VARCHAR(50), Version VARCHAR(200));
EXECUTE master.sys.sp_MSforeachdb '
USE [?];
IF EXISTS
( SELECT 1
FROM sys.tables
WHERE [Object_ID] = OBJECT_ID(N''dbo.DBVersion'')
)
BEGIN
INSERT #tmp (DatabaseName, Version)
SELECT ''?'', [Version]
FROM dbo.DBVersion
END';
SELECT *
FROM #tmp;
DROP TABLE #tmp;
对使用未记录的过程有一些怀疑,所以你可以用游标重写它:
CREATE TABLE #tmp (DatabaseName VARCHAR(50), Version VARCHAR(200));
DECLARE DBCursor CURSOR LOCAL STATIC FORWARD_ONLY READ_ONLY
FOR
SELECT Name
FROM sys.databases;
OPEN DBCursor;
DECLARE @DBName VARCHAR(200) = '';
FETCH NEXT FROM DBCursor INTO @DBName;
WHILE @@FETCH_STATUS != 0
BEGIN
DECLARE @SQL NVARCHAR(MAX) = N'USE ' + QUOTENAME(@DBName) + '
IF EXISTS
( SELECT 1
FROM sys.tables
WHERE [Object_ID] = OBJECT_ID(N''dbo.DBVersion'')
)
BEGIN
INSERT #tmp (DatabaseName, Version)
SELECT @DB, [Version]
FROM dbo.DBVersion
END';
EXECUTE SP_EXECUTESQL @SQL, N'@DB VARCHAR(200)', @DBName;
FETCH NEXT FROM DBCursor INTO @DBName;
END
CLOSE DBCursor;
DEALLOCATE DBCursor;
SELECT *
FROM #tmp;
DROP TABLE #tmp;