在維護SQL Server資料庫的過程中,大家是不是經常會遇到成千上萬的類似log20050901 這種日誌表,每一個表中資料都不是很多,一個一個開啟看非常不方便,或者有時候我們需要把這些表中的資料匯總,一個一個開啟操作也是很麻煩。下面就介紹了一種自動化的合并表的方法。
我的思路是建立一個使用者預存程序來完成一系列自動化的操作,以下是代碼。
--預存程序我命名為BackupData,可以使用自己定義的名稱。
--參數1:@TableTarget 產生的目標表的名稱
--參數2:@TableStart 合并開始的表名
--參數3:@TableEnd 合并結束的表名
CREATE PROCEDURE BackupData @TableTarget sysname,@TableStart sysname,@TableEnd sysname
AS
DECLARE tnames_cursor CURSOR
FOR
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
OPEN tnames_cursor
DECLARE @TableName sysname
DECLARE @TablePref sysname
DECLARE @IsTargetExist integer
--判斷目標表是否存在
SET @IsTargetExist=(SELECT count(TABLE_NAME) FROM INFORMATION_SCHEMA.TABLES where table_name = @TableTarget)
--如果目標表不存在則建立表
IF @istargetexist=0
BEGIN
--EXEC中的語句可以用SQL Server編寫的表指令碼替換。注意在目標表中不能夠存在與需合并表中名稱一樣的“自動編號”類型的欄位。
EXEC ('CREATE TABLE [dbo].[' @TableTarget ']
(
[LOG1] [nvarchar] (10) COLLATE Chinese_PRC_CI_AS NULL ,
[LOG2] [nvarchar] (10) COLLATE Chinese_PRC_CI_AS NULL ,
……
)')
END
FETCH NEXT FROM tnames_cursor INTO @TableName
WHILE (@@FETCH_STATUS <> -1)
BEGIN
IF (@@FETCH_STATUS <> -2)
BEGIN
SELECT @TableName = RTRIM(@TableName)
--以下兩行根據日誌表的名稱更改
--取日誌表名的前3位作為標識
SELECT @TablePref = LEFT(@TableName,3)
--判斷表名是否附合要求
IF (@TablePref='log') and (@TableName>=@TableStart) and (@TableName<=@TableEnd)
--開始匯入
http://www.bkjia.com/PHPjc/631117.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/631117.htmlTechArticle在維護SQL Server資料庫的過程中,大家是不是經常會遇到成千上萬的類似log20050901 這種日誌表,每一個表中資料都不是很多,一個一個開啟看...