存储过程自动转成C#源码过程

开发 后端
本文是一个国外程序员写的自动将存储过程转成C#源码的存储过程。

本文介绍将存储过程转成C#源码的方法。以下是存储过程的源代码:

  1. CREATE     PROCEDURE dbo.tools_CS_SPROC_Builder  
  2. (  
  3. @objName nvarchar(100)  
  4. )  
  5. AS  
  6. /*  
  7. ___________________________________________________________________  
  8. Name:  CS SPROC Builder  
  9. Version: 1  
  10. Date:  20/06/2004  
  11. Author:  Paul McKenzie  
  12. Description: Call this stored procedue passing the name of your   
  13.   database object that you wish to insert/update  
  14.   from .NET (C#) and the code returns code to copy  
  15.   and paste into your application.  This version is  
  16.   for use with "Microsoft Data Application Block".  
  17. Sample:    
  18.   EXEC tools_CS_SPROC_Builder 'InsertSQL'  
  19. */ 
  20. SET NOCOUNT ON  
  21.  
  22. DECLARE @parameterCount int 
  23. DECLARE @errMsg varchar(100)  
  24. DECLARE @parameterAt varchar(1)  
  25. DECLARE @connName varchar(100)  
  26.  
  27. SET @connName='conn.Connection' 
  28. SET @parameterAt='' 
  29.     
  30. SELECT   
  31.  dbo.sysobjects.name AS ObjName,   
  32.  dbo.sysobjects.xtype AS ObjType,  
  33.  dbo.syscolumns.name AS ColName,   
  34.  dbo.syscolumns.colorder AS ColOrder,   
  35.  dbo.syscolumns.length AS ColLen,   
  36.  dbo.syscolumns.colstat AS ColKey,   
  37.  dbo.systypes.xtype  
  38. INTO #t_obj  
  39. FROM           
  40.  dbo.syscolumns INNER JOIN  
  41.  dbo.sysobjects ON dbo.syscolumns.id = dbo.sysobjects.id INNER JOIN  
  42.  dbo.systypes ON dbo.syscolumns.xtype = dbo.systypes.xtype  
  43. WHERE       
  44.  (dbo.sysobjects.name = @objName)   
  45.  AND   
  46.  (dbo.systypes.status < > 1)   
  47. ORDER BY   
  48.  dbo.sysobjects.name,   
  49.  dbo.syscolumns.colorder  
  50.  
  51. SET @parameterCount=(SELECT count(*) FROM #t_obj)  
  52.  
  53. IF(@parameterCount< 1) SET @errMsg='No Parameters/Fields found for ' + @objName  
  54.  
  55. IF(@errMsg is null)  
  56.  BEGIN  
  57.   PRINT 'try' 
  58.   PRINT '   {' 
  59.   PRINT '   SqlParameter[] paramsToStore = new SqlParameter[' + cast(@parameterCount as varchar) + '];' 
  60.   PRINT '' 
  61.     
  62.   DECLARE @source_name nvarchar,@source_type varchar,@col_name nvarchar(100),@col_order int,@col_type varchar(20),@col_len int,@col_key int,@col_xtype int,@col_redef varchar(20)  
  63.    
  64.   DECLARE cur CURSOR FOR  
  65.   SELECT * FROM #t_obj  
  66.   OPEN cur  
  67.   -- Perform the first fetch.  
  68.   FETCH NEXT FROM cur  
  69.   INTO @source_name,@source_type,@col_name,@col_order,@col_len,@col_key,@col_xtype  
  70.    
  71.   if(@source_type=N'U') SET @parameterAt='@' 
  72.   -- Check @@FETCH_STATUS to see if there are any more rows to fetch.  
  73.   WHILE @@FETCH_STATUS = 0  
  74.   BEGIN  
  75.    SET @col_redef=(SELECT   
  76.       CASE @col_xtype  
  77.     WHEN 34 THEN 'Image' 
  78.     WHEN 35 THEN 'Text' 
  79.     WHEN 48 THEN 'TinyInt' 
  80.     WHEN 52 THEN 'SmallInt' 
  81.     WHEN 56 THEN 'Int' 
  82.     WHEN 58 THEN 'SmallDateTime' 
  83.     WHEN 59 THEN 'Real' 
  84.     WHEN 60 THEN 'Money' 
  85.     WHEN 61 THEN 'DateTime' 
  86.     WHEN 62 THEN 'Float' 
  87.     WHEN 99 THEN 'NText' 
  88.     WHEN 104 THEN 'Bit' 
  89.     WHEN 106 THEN 'Decimal' 
  90.     WHEN 122 THEN 'SmallMoney' 
  91.     WHEN 127 THEN 'BigInt' 
  92.     WHEN 165 THEN 'VarBinary' 
  93.     WHEN 167 THEN 'VarChar' 
  94.     WHEN 173 THEN 'Binary' 
  95.     WHEN 175 THEN 'Char' 
  96.     WHEN 231 THEN 'NVarChar' 
  97.     WHEN 239 THEN 'NChar' 
  98.     ELSE '!MISSING' 
  99.  
  100.       END AS C)   
  101.    --Write out the parameter  
  102.    PRINT '   paramsToStore[' + cast(@col_order-1 as varchar)   
  103.     + '] = new SqlParameter("' + @parameterAt + @col_name  
  104.     + '", SqlDbType.' + @col_redef  
  105.     + ');' 
  106.  
  107.    --If the type is a string then output the size declaration  
  108.    IF(@col_xtype=231)OR(@col_xtype=167)OR(@col_xtype=175)OR(@col_xtype=99)OR(@col_xtype=35)  
  109.     BEGIN  
  110.     PRINT '   paramsToStore[' + cast(@col_order-1 as varchar)   
  111.      + '].Size=' + cast(@col_len as varchar) + ';' 
  112.     END  
  113.    PRINT '   paramsToStore['+ cast(@col_order-1 as varchar)   
  114.     + '].Value =  ;' 
  115.       -- This is executed as long as the previous fetch succeeds.  
  116.       FETCH NEXT FROM cur  
  117.    INTO @source_name,@source_type,@col_name,@col_order,@col_len,@col_key,@col_xtype   
  118.   END  
  119.   PRINT '' 
  120.   PRINT '   SqlHelper.ExecuteNonQuery(' + @connName + ', CommandType.StoredProcedure,"' + @objName + '", paramsToStore);' 
  121.   PRINT '   }' 
  122.   PRINT 'catch(Exception excp)' 
  123.   PRINT '   {' 
  124.   PRINT '   }' 
  125.   PRINT 'finally' 
  126.   PRINT '   {' 
  127.   PRINT '   ' + @connName + '.Dispose();' 
  128.   PRINT '   ' + @connName + '.Close();' 
  129.   PRINT '   }'    
  130.   CLOSE cur  
  131.   DEALLOCATE cur  
  132.  END  
  133.  
  134. if(LEN(@errMsg)>0) PRINT @errMsg  
  135. DROP TABLE #t_obj  
  136. SET NOCOUNT ON  
  137.  
  138. GO  
  139.  

示例:存储过程名'1_Proc_admin_publish'

  1. exec dbo.tools_CS_SPROC_Builder '1_Proc_admin_publish' 

显示结果如下(C#源码):

  1. try 
  2.    {  
  3.    SqlParameter[] paramsToStore = new SqlParameter[4];  
  4.    
  5.    paramsToStore[0] = new SqlParameter("@memberName", SqlDbType.VarChar);  
  6.    paramsToStore[0].Size=60;  
  7.    paramsToStore[0].Value =  ;  
  8.    paramsToStore[1] = new SqlParameter("@type", SqlDbType.Int);  
  9.    paramsToStore[1].Value =  ;  
  10.    paramsToStore[2] = new SqlParameter("@static", SqlDbType.Int);  
  11.    paramsToStore[2].Value =  ;  
  12.    paramsToStore[3] = new SqlParameter("@returnType", SqlDbType.Int);  
  13.    paramsToStore[3].Value =  ;  
  14.    
  15.    SqlHelper.ExecuteNonQuery(conn.Connection, CommandType.StoredProcedure,"1_Proc_admin_publish", paramsToStore);  
  16.    }  
  17. catch(Exception excp)  
  18.    {  
  19.    }  
  20. finally 
  21.    {  
  22.    conn.Connection.Dispose();  
  23.    conn.Connection.Close();  
  24.    } 

以上就是自动将存储过程转成C#源码的存储过程,希望对有些人会有帮助。

【编辑推荐】

  1. C#基础知识一览
  2. 学习C#自定义用户控件
  3. C#自定义组件和用户组件属性的设置
  4. C#编程中的组件-事件-委托
  5. Visual C#自定义组件的设计:Pop3Com组件
责任编辑:book05 来源: cnblogs
相关推荐

2009-08-13 17:58:34

C#存储过程

2009-08-17 18:30:29

C# SQL Serv

2009-08-07 03:47:00

2009-08-06 16:18:38

C#调用SQL存储过程

2010-04-16 11:22:08

Oracle存储过程

2010-07-08 17:15:04

SQL Server存

2009-08-04 10:29:06

在C#中使用存储过程

2009-08-05 08:42:41

C#中用Oracle执DataSet

2009-09-01 11:07:58

C#项目

2010-09-07 16:46:56

SQL语句nsert

2010-07-15 12:38:14

SQL Server存

2009-08-25 15:48:03

C#数组操作

2009-07-03 10:33:07

C#创建COM组件

2009-08-14 15:07:00

C#编译过程

2009-08-26 09:48:48

C#异步套接字

2009-08-25 11:13:28

C#获取逻辑硬盘信息

2009-09-03 17:54:04

C#开发浏览器

2009-09-02 16:20:22

C#动态创建数组

2020-11-26 10:33:44

MySQL存储函数

2009-09-17 10:04:32

LINQ存储过程
点赞
收藏

51CTO技术栈公众号