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

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

成都创新互联主营双滦网站建设的网络公司,主营网站建设方案,成都app开发,双滦h5微信小程序开发搭建,双滦网站营销推广欢迎双滦等地区企业咨询

 
 
 
  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组件

文章题目:存储过程自动转成C#源码过程
文章源于:http://www.hantingmc.com/qtweb/news15/90215.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联