色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:112日期:2023-10-29 16:22:38

在維護(hù)SQL Server數(shù)據(jù)庫的過程中,大家是不是經(jīng)常會(huì)遇到成千上萬的類似log20050901 這種日志表,每一個(gè)表中數(shù)據(jù)都不是很多,一個(gè)一個(gè)打開看非常不方便,或者有時(shí)候我們需要把這些表中的資料匯總,一個(gè)一個(gè)打開操作也是很麻煩。下面就介紹了一種自動(dòng)化的合并表的方法。

我的思路是創(chuàng)建一個(gè)用戶存儲(chǔ)過程來完成一系列自動(dòng)化的操作,以下是代碼。

--存儲(chǔ)過程我命名為BackupData,可以使用自己定義的名稱。

--參數(shù)1:@TableTarget 生成的目標(biāo)表的名稱

--參數(shù)2:@TableStart 合并開始的表名

--參數(shù)3:@TableEnd 合并結(jié)束的表名

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

--判斷目標(biāo)表是否存在

SET @IsTargetExist=(SELECT count(TABLE_NAME) FROM INFORMATION_SCHEMA.TABLES where table_name = @TableTarget)

--如果目標(biāo)表不存在則新建表

IF @istargetexist=0

BEGIN

--EXEC中的語句可以用SQL Server編寫的表腳本替換。注意在目標(biāo)表中不能夠存在與需合并表中名稱一樣的“自動(dòng)編號(hào)”類型的字段。

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)

--以下兩行根據(jù)日志表的名稱更改

--取日志表名的前3位作為標(biāo)識(shí)

SELECT @TablePref = LEFT(@TableName,3)

--判斷表名是否附合要求

IF (@TablePref='log') and (@TableName>=@TableStart) and (@TableName<=@TableEnd)

--開始導(dǎo)入

BEGIN

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

PRINT '表' + @TableName + '已導(dǎo)入' + @TableTarget + '中'

END

END

FETCH NEXT FROM tnames_cursor INTO @TableName

END

--釋放內(nèi)存

CLOSE tnames_cursor

DEALLOCATE tnames_cursor

把上面代碼在SQL查詢分析器中運(yùn)行即生成存儲(chǔ)過程BackupData。

BackupData的使用方法如下:

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

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

因?yàn)槲覜]有找到可以實(shí)現(xiàn)這種操作的SQL語句所以寫了這樣的存儲(chǔ)過程,如果大家有好的更簡(jiǎn)單的辦法請(qǐng)給我留言或來信:[email protected]。

標(biāo)簽: Sql Server 數(shù)據(jù)庫
主站蜘蛛池模板: 国产一级爱c片免费播放 | 亚洲日本在线观看视频 | 国产精品成人久久久 | 日韩中文字幕精品一区在线 | 亚洲男人的天堂视频 | 国产成人久久久精品一区二区三区 | 黄色成人免费网站 | 美国免费三片在线观看 | 中文字幕水野优香在线网在线 | 国产美女精品在线 | a色毛片免费视频 | 一级毛片免费不卡夜夜欢 | www毛片com| 欧美成人精品免费播放 | 国产亚洲精品hd网站 | 国产精品亚洲国产三区 | 久久99精品一级毛片 | 久久亚洲精品一区成人 | 久久这里只有精品免费视频 | 亚洲a在线播放 | 男人操美女逼视频 | 清纯唯美综合网 | 国产一区二区精品久久91 | 久久99国产亚洲精品 | 国产精品一区二区久久精品 | 亚洲国产欧美一区二区欧美 | 成人18在线视频播放 | 国产91一区二这在线播放 | 欧美一区二区三区在线播放 | www.日本三级 | 欧产日产国产精品精品 | 成年大片免费视频播放二级 | 成人精品视频网站 | 日韩视频免费一区二区三区 | 真正国产乱子伦高清对白 | 手机看片精品国产福利盒子 | 国产草草影院 | 亚洲精品在线观看视频 | 日韩欧美第一页 | 亚洲成av人片在线观看无码 | 精品午夜寂寞黄网站在线 |