在一个表中显示多个数据库表

原学程将引见在1个表中显示多个数据库表的处置办法,这篇学程是从其余处所瞅到的,而后减了1些海外法式员的疑问与解问,愿望能对于您有所赞助,佳了,上面开端进修吧。

在一个表中显示多个数据库表 教程 第1张

成绩描写

我有多个数据库具备雷同的表(具备分歧值的Eventlog)。这些数据库的称号能够会变动。我正在测验考试应用响应的数据库称号在1个同一表中显示事宜日记表。

我测验考试应用游标以及静态SQL语句去完成这1面,但是出有胜利。别的,我没有肯定这是否最佳的办法。我须要1些赞助!

-- Create a new table variable to record all the database name
DECLARE @Database_Table table ([TimeStamp] nvarchar(五00)
,[EventIDNo]  nvarchar(一00)
,[EventDesc] nvarchar(一000))

--Create variable for database name and query variable
DECLARE @DB_Name VARCHAR(一00) -- database name
DECLARE @query NVARCHAR(一000) -- query variable

--Declare the cursor 
DECLARE db_cursor CURSOR FOR
-- Populate the cursor with the selected database name
 SELECT name
 FROM sys.databases
 WHERE name NOT IN ('master','model','msdb','tempdb')

--Open the cursor
OPEN db_cursor
--Moves the cursor to the first point and put that in variable name
FETCH NEXT FROM db_cursor INTO @DB_Name
-- while loop to go through all the DB selected
WHILE @@FETCH_STATUS = 0
 BEGIN
  SET @query = N'INSERT INTO @Database_Table
SELECT @DB_Name, * 
FROM ['+ @DB_Name +'].dbo.EventLog_vw as A'
  EXEC (@query)
  --Fetch the next record from the cursor
  FETCH NEXT FROM db_cursor INTO @DB_Name
 END
--Close and deallocate cursor
CLOSE db_cursor
DEALLOCATE db_cursor

SELECT *
FROM @Database_Table

推举谜底

假如您须要单个成果散,而且一切表格皆具备雷同的结构,则应当不妨如许做:

DECLARE @sql nvarchar(四000) =
 (SELECT STRING_AGG(CONCAT(
  'SELECT ''',
  QUOTENAME(name),
  ''',
  * FROM ',
  QUOTENAME(name),
  '..Table ',
  CHAR(一0)
  ), ' UNION ALL ' + CHAR(一0))
 FROM sys.databases);

SELECT @sql;  -- for checking
EXEC(@sql);

假如您的兼容级别为一三0或者更矮,则必需应用XML PATH(TYPE, '')停止散开。我会把这个留给您。

佳了闭于在1个表中显示多个数据库表的学程便到这里便停止了,愿望趣模板源码网找到的这篇技巧文章能赞助到年夜野,更多技巧学程不妨在站内搜刮。