• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

应用存储过程按月建数据表_sqlserver

sqlserver 搞代码 7年前 (2018-06-16) 120次浏览 已收录 0个评论

        为了方便数据库的存储、数据的备份、恢复,在实际建库中,我们希望能够根据具体的年月建立数据表,例如,事件表我们可以建立为EV_yyyymm(yyyy为年份,mm为月份),使用存储过程可以解决动态建表。(源代码如下:)

****************************************************
***                存储过程原码                  ***
****************************************************

http://www.gaodaima.com/34944.html应用存储过程按月建数据表_sqlserver

====生成表的存储过程prCreateDateTable===
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS OFF
GO

ALTER             PROCEDURE prCreateDateTable
AS  
–初始化  
    DECLARE @intErrorCode int,         –错误号,成功显示0
   @dtmCheckDay datetime,     –系统当前时间
   @str varchar(40),@SubStr varchar(10),
   @chrnSQL nvarchar(1000)   –SQL查询语句
    DECLARE @chvSuffixTableName  varchar(50),     –表名称的日期后缀
    @chvFinalTableName1 varchar(40),        –待检测的表名称
    @chvFinalTableName2 varchar(40),
    @chvFinalTableName3 varchar(40),
    @chvFinalTableName4 varchar(40),
    @chvFinalTableName5 varchar(40),
    @chvFinalTableName6 varchar(40),
    @chvFinalTableName7 varchar(40),
    @chvFinalTableName8 varchar(40)

    SELECT @dtmCheckDay = getdate()
    SELECT @chvSuffixTableName = dbo.fnFormatDate_month(@dtmCheckDay)   —取格式化后的月用到自定义函数

    SELECT @chvFinalTableName1  = ‘EV_’ + ‘_’ + @chvSuffixTableName 

    –查询有无@chvTableName_XXXXXX(年月),即@chvFinalTableName表,如果没有则建立
BEGIN
 IF NOT EXISTS (SELECT * FROM sysobjects WHERE NAME = @chvFinalTableName1 AND xtype=’U’)    — 事件表
    BEGIN
     SELECT @chrnSQL=’ CREATE TABLE [dbo].[‘+ @chvFinalTableName8 +’]( ‘
      +'[EVID] [char] (12) COLLATE Chinese_PRC_CI_AS NOT NULL ,’
      +'[StarTime] [datetime] NOT NULL ,’
      +'[StarStake] [varchar] (9) COLLATE Chinese_PRC_CI_AS NOT NULL ,’
      +'[EndStake] [varchar] (9) COLLATE Chinese_PRC_CI_AS NOT NULL ,’
      +'[Direcation] [char] (1) COLLATE Chinese_PRC_CI_AS NOT NULL ,’
      +'[EvType] [varchar] (3) COLLATE Chinese_PRC_CI_AS NOT NULL ,’
      +'[EndTime] [datetime] NULL ,’
      +'[Description] [varchar] (200) COLLATE Chinese_PRC_CI_AS NULL ,’
      +'[Advice] [varchar] (200) COLLATE Chinese_PRC_CI_AS NULL ,’
      +'[EconLoss] [int] NULL ,’
      +'[DeathToll] [tinyint] NULL, ‘
      +’ CONSTRAINT ‘+ @chvFinalTableName8 +’_PK ‘+’ PRIMARY KEY CLUSTERED ([EVID])  ON [PRIMARY]’
      +’)  ON [PRIMARY]’
           EXEC sp_ExecuteSql @chrnSQL
  END
END;

GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO

===得到日期的自定义函数====
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_NULLS ON
GO

ALTER  FUNCTION fnFormatDate_Month (@DATE datetime)
RETURNS  varchar(50)
AS 
BEGIN
 declare @intDateYear int,    —需要处理数据的年份
   @intDateMonthNo int         —需要处理数据的月份
 declare @chvMonthNo varchar(10) ,
   @chvTableName  varchar(50)

 select @intDateYear = year(@DATE )
 select @intDateMonthNo = month(@DATE)select  @chvMonthNo=’00’+convert(varchar(2),@intDateMonthNo)
 select  @chvMonthNo=substring(@chvMonthNo,len(@chvMonthNo)-1 ,2
 select  @chvTableName=convert(varchar(4),@intDateYear)+@chvMonthNo
 return (@chvTableName)
END

GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO
============================================================

刚毕业,做软件,初学使用存储过程。

欢迎大家阅读《应用存储过程按月建数据表_sqlserver,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:应用存储过程按月建数据表_sqlserver

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址