亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

SQL Server中合并用戶日志表的方法

添加時間:2012-12-30 17:47:19  添加: 思海網絡 

在維護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)

         --開始導入

 

         BEGIN

            EXEC ('INSERT INTO ' + @TableTarget + ' SELECT * FROM ' + @TableName )

            PRINT '表' + @TableName + '已導入' + @TableTarget + '中'

         END

   END

   FETCH NEXT FROM tnames_cursor INTO @TableName

END

--釋放內存

CLOSE tnames_cursor

DEALLOCATE tnames_cursor

把上面代碼在SQL查詢分析器中運行即生成存儲過程BackupData。

BackupData的使用方法如下:

EXEC BackupData ‘合并后表名’,’開始表名’,’結束表名’,例如:

EXEC BackupData ‘_logs200508’,’log200508000000’,’log200508319999’。

因為我沒有找到可以實現這種操作的SQL語句所以寫了這樣的存儲過程。

關鍵字:SQL Server、日志表

分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站