现在的位置: 首页 > 综合 > 正文

通用存储过程之一:插入、更新、删除存储过程。

2013年01月23日 ⁄ 综合 ⁄ 共 4940字 ⁄ 字号 评论关闭
--临时存储过程如下:

CREATE PROC #AutoGeneration_IUD_P
@TABLENAME VARCHAR(50),
@FLAT  TINYINT
AS
BEGIN
 
DECLARE @HOST_NAME VARCHAR(200)
 
DECLARE @GET_DATE DATETIME
 
SELECT @HOST_NAME=HOST_NAME(),@GET_DATE=GETDATE()
 
IF @FLAT=1 --插入
 BEGIN
 
DECLARE @INSERT_SQLROC NVARCHAR(4000)
 
DECLARE @INSERT_SQL VARCHAR(8000)
 
DECLARE @INSERT_PARAMETER VARCHAR(8000)
 
DECLARE @INSERT_DESCRIPTION VARCHAR(8000)
 
DECLARE @INSERT_REMARK VARCHAR(2000)
 
DECLARE @INSERT_COLUMN VARCHAR(8000)
 
SELECT @INSERT_SQLROC='',@INSERT_SQL='',@INSERT_PARAMETER='',@INSERT_DESCRIPTION='',
   
@INSERT_REMARK='',@INSERT_COLUMN=''
 
SET @INSERT_SQLROC=@INSERT_SQLROC+'IF EXISTS (SELECT 1 FROM SYSOBJECTS WHERE ID=OBJECT_ID(''SP_'+@TABLENAME+'_AddNew'') AND XTYPE IN (N''P''))'+CHAR(10)
 
SET @INSERT_SQLROC=@INSERT_SQLROC+SPACE(5)+'DROP PROC SP_'+@TABLENAME+'_AddNew'+CHAR(10)
 
SET @INSERT_SQLROC=@INSERT_SQLROC+'GO '
 
SELECT @INSERT_PARAMETER=@INSERT_PARAMETER+SPACE(4)+'@'+LTRIM(NAME)+SPACE(15-LEN(NAME))+
     
CASE WHEN xtype=34 THEN 'image'
       
WHEN xtype=35 THEN 'text'
       
WHEN xtype=36 THEN 'uniqueidentifier'
       
WHEN xtype=48 THEN 'tinyint'
       
WHEN xtype=52 THEN 'smallint'
       
WHEN xtype=56 THEN 'int'
       
WHEN xtype=58 THEN 'smalldatetime'
       
WHEN xtype=59 THEN 'real'
       
WHEN xtype=60 THEN 'money'
       
WHEN xtype=61 THEN 'datetime'
       
WHEN xtype=62 THEN 'float'
       
WHEN xtype=98 THEN 'sql_variant'
       
WHEN xtype=99 THEN 'ntext'
       
WHEN xtype=104 THEN 'bit'
       
WHEN xtype=106 THEN 'decimal'
       
WHEN xtype=108 THEN 'numeric'
       
WHEN xtype=122 THEN 'smallmoney'
       
WHEN xtype=127 THEN 'bigint'
       
WHEN xtype=165 THEN 'varbinary'
          
WHEN xtype=167 THEN 'varchar'+'('+LTRIM(length)+')'
       
WHEN xtype=173 THEN 'binary'
       
WHEN xtype=175 THEN 'char'+'('+LTRIM(length)+')'
       
WHEN xtype=189 THEN 'timestamp'
       
WHEN xtype=231 THEN 'nvarchar'+'('+LTRIM(length)+')'
       
WHEN xtype=239 THEN 'nchar'+'('+LTRIM(length)+')'
       
WHEN xtype=241 THEN 'xml'
       
WHEN xtype=231 THEN 'sysname' END+','+CHAR(10),
   
@INSERT_REMARK=@INSERT_REMARK+',@'+NAME,
   
@INSERT_COLUMN=@INSERT_COLUMN+','+NAME
 
FROM
  ( 
  
SELECT NAME,CDEFAULT,A.ID,XTYPE,LENGTH,COLORDER
  
FROM SYSCOLUMNS A 
  
WHERE A.ID=OBJECT_ID(''+@TABLENAME+'')
  
AND COLUMNPROPERTY(A.ID,A.NAME,'IsIdentity')<>1 
  )TB
 
ORDER BY COLORDER
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'/*+--------------------------------------+'+CHAR(10)
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'| 过程名称:SP_'+@TABLENAME+'_AddNew'+CHAR(10)
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'| 功能说明:插入表'+@TABLENAME+'的存储过程'+CHAR(10)
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'| 入口参数:'+STUFF(@INSERT_REMARK,1,1,'')+''+CHAR(10)
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'| 过程返回:无返回记录'+CHAR(10)
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'| 维护记录:Y/A'+CHAR(10)
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'| 使用案例:SP_'+@TABLENAME+'_AddNew'+CHAR(10)
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'| 工作站名:'+@HOST_NAME+''+CHAR(10)
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'| 联系方式:ZLP321001@HOTMAIL.COM'+CHAR(10)
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'| 创建日期:'+CONVERT(VARCHAR(20),@GET_DATE,120)+''+CHAR(10
 
SET @INSERT_DESCRIPTION=@INSERT_DESCRIPTION+'+--------------------------------------+*/'+CHAR(10)
 
SELECT @INSERT_SQLROC=@INSERT_SQLROC+CHAR(10)+@INSERT_DESCRIPTION+'CREATE PROC SP_'+@TABLENAME+'_AddNew'
 
SET @INSERT_SQLROC=@INSERT_SQLROC+CHAR(13)+CHAR(10)+LEFT(@INSERT_PARAMETER,LEN(@INSERT_PARAMETER)-2)+CHAR(10)
 
SET @INSERT_SQLROC=@INSERT_SQLROC+'AS'+CHAR(10)+'BEGIN'
 
SET @INSERT_SQLROC=@INSERT_SQLROC+CHAR(10)+SPACE(4)+'SET NOCOUNT ON'
 
SET @INSERT_SQL=SPACE(8)+'INSERT INTO '+@TABLENAME+'('+STUFF(@INSERT_COLUMN,1,1,'')+')'+CHAR(13)+CHAR(10)+SPACE(8)+' SELECT '+STUFF(@INSERT_REMARK,1,1,'')
 
SET @INSERT_SQLROC=@INSERT_SQLROC+CHAR(10)+CHAR(32)+@INSERT_SQL
 
SET @INSERT_SQLROC=@INSERT_SQLROC+CHAR(10)+SPACE(8)+' SELECT _ROWCOUNT=@@ROWCOUNT'
 
SET @INSERT_SQLROC=@INSERT_SQLROC+CHAR(10)+SPACE(4)+'SET NOCOUNT OFF' 
 
SET @INSERT_SQLROC=@INSERT_SQLROC+CHAR(10)+'END'
 
PRINT @INSERT_SQLROC+CHAR(10)+'GO '
 
--EXEC(@INSERT_SQLROC)
 --EXEC SP_EXECUTESQL @INSERT_SQLROC
 END
 
IF @FLAT=2 --修改
 BEGIN
 
DECLARE @UPDATE_SQLROC VARCHAR(8000)
 
DECLARE @UPDATE_SQL VARCHAR(8000
 
DECLARE @UPDATE_PARAMETER VARCHAR(1000)
 
DECLARE @UPDATE_DESCRIPTION VARCHAR(1000)
 
DECLARE @UPDATE_REMARK VARCHAR(1000)
 
DECLARE @UPDATE_KEY_COLUMN VARCHAR(1000)
 
DECLARE @UPDATE_COLUMN VARCHAR(5000)
 
SELECT  @UPDATE_SQLROC='',
   
@UPDATE_SQL='',@UPDATE_PARAMETER='',@UPDATE_DESCRIPTION='',
   
@UPDATE_REMARK='',@UPDATE_KEY_COLUMN='',@UPDATE_COLUMN=''
 
SET @UPDATE_SQLROC=@UPDATE_SQLROC+'IF EXISTS (SELECT 1 FROM SYSOBJECTS WHERE ID=OBJECT_ID(''SP_'+@TABLENAME+'_Update'') AND XTYPE IN (N''P''))'+CHAR(10)
 
SET @UPDATE_SQLROC=@UPDATE_SQLROC+SPACE(5)+'DROP PROC SP_'+@TABLENAME+'_Update'+CHAR(10)
 
SET @UPDATE_SQLROC=@UPDATE_SQLROC+' GO '
 
SELECT @UPDATE_PARAMETER=@UPDATE_PARAMETER+SPACE(4)+'@'+LTRIM(NAME)+SPACE(15-LEN(NAME))+
     
CASE WHEN xtype=34 THEN 'image'
 

抱歉!评论已关闭.