ASP.NET调用存储过程两种方法浅析
创始人
2024-04-21 04:01:00
0

ASP.NET调用存储过程的方法的介绍呢,我们为了突出新方法的优点,首先介绍一下在.NET中调用存储过程的“官方”方法。另外,本文的所有示例程序均工作于SqlServer数据库上,其它情况类似,以后不再一一说明。本文所有例子均采用C#语言。

要在应用程序中访问数据库,一般性的步骤是:首先声明一个数据库连接SqlConnection,然后声明一个数据库命令SqlCommand,用来执行SQL语句和存储过程。有了这两个对象后,就可以根据自己的需要采用不同的执行方式达到目的。需要补充的是,不要忘记在页面上添加如下的引用语句:using System.Data.SqlClient。

就执行存储过程来说,如果执行的是***类存储过程,那么就要用一个DataAdapter将结果填充到一个DataSet中,然后就可以使用数据网格控件将结果呈现在页面上了;如果执行的是第二和第三种存储过程,则不需要此过程,只需要根据特定的返回判定操作是否成功完成即可。

ASP.NET调用存储过程(1)执行一个没有参数的存储过程的代码如下:

  1. SqlConnection conn=new SqlConnection(“connectionString”);  
  2. SqlDataAdapter da = new SqlDataAdapter();  
  3. da.SelectCommand = new SqlCommand();  
  4. da.SelectCommand.Connection = conn;  
  5. da.SelectCommand.CommandText = "NameOfProcedure";  
  6. da.SelectCommand.CommandType = CommandType.StoredProcedure; 

然后只要选择适当的方式执行此处过程,用于不同的目的即可。

ASP.NET调用存储过程(2)执行一个有参数的存储过程的代码如下(我们可以将调用存储过程的函数声明为ExeProcedure(string inputdate)):

  1. SqlConnection conn=new SqlConnection(“connectionString”);  
  2. SqlDataAdapter da = new SqlDataAdapter();  
  3. da.SelectCommand = new SqlCommand();  
  4. da.SelectCommand.Connection = conn;  
  5. da.SelectCommand.CommandText = "NameOfProcedure";  
  6. da.SelectCommand.CommandType = CommandType.StoredProcedure;  
  7. (以上代码相同,以下为要添加的代码)  
  8. param = new SqlParameter("@ParameterName", SqlDbType.DateTime);  
  9. param.Direction = ParameterDirection.Input;  
  10. param.Value = Convert.ToDateTime(inputdate);  
  11. da.SelectCommand.Parameters.Add(param); 

这样就添加了一个输入参数。若需要添加输出参数:

  1. param = new SqlParameter("@ParameterName", SqlDbType.DateTime);  
  2. param.Direction = ParameterDirection.Output;  
  3. param.Value = Convert.ToDateTime(inputdate);  
  4. da.SelectCommand.Parameters.Add(param); 

若要获得参储过程的返回值:

  1. param = new SqlParameter("@ParameterName", SqlDbType.DateTime);  
  2. param.Direction = ParameterDirection.ReturnValue;  
  3. param.Value = Convert.ToDateTime(inputdate);  
  4. da.SelectCommand.Parameters.Add(param); 

从上面的代码我们可以看出,当存储过程比较多或者存储过程的参数比较多时,这种方法会大大影响开发的速度;另外一方面,如果项目比较大,那么这些用于数据库逻辑的函数在以后的维护中也是一个很大的负担。那么,有没有一种改进的方法可以解决这个问题呢?想到在执行没有参数的存储过程时只需要传入一个存储过程的名字就可以调用相应的存储过程,而且在SqlServer数据库中我们可以直接在查询分析器中敲入“存储过程名(参数列表)”样的字符串就可以执行存储过程,那么,是否可以把这种思想应用到应用程序中呢?

于是在编译器中键入相应代码。这些代码是在调用不带参数的存储过程的代码的基础上改的。具体代码如下:

  1. SqlConnection conn=new SqlConnection(“connectionString”);  
  2. SqlDataAdapter da = new SqlDataAdapter();  
  3. da.SelectCommand = new SqlCommand();  
  4. da.SelectCommand.Connection = conn;  
  5. da.SelectCommand.CommandText = "NameOfProcedure(’para1’,’para2’,para3)";  
  6. da.SelectCommand.CommandType = CommandType.StoredProcedure; 

为了使代码更具有代表性,要调用的存储过程的***个和第二个参数都为字符串类型,第三个参数为整型。执行以后发现,完全可以达到预期的效果!

两种ASP.NET调用存储过程方法的比较

通过比较我们可以看到,第二种方法具有一个很明显的优点,那就是可以提高开发速度,节省开发时间,而且代码容易维护,在一定程度上也减少了系统大小。但是,由于对存储过程参数的处理比较笼统,如果要获取输出参数或者得到存储过程的返回值,这种方法就不能满足需要了。虽然如此,但是,这种方法毕竟可以让开发人员少些很大一部分的代码。如果不需要获取输出参数和返回值,那么几乎可以做到“一劳永逸”。因此在实际的程序开发中,这种方法还是具有一定的实用价值的。

ASP.NET调用存储过程两种方法就向你介绍到这里,希望对你有所帮助。

【编辑推荐】

  1. ASP.NET中Cookie删除的代码浅析
  2. ASP.NET编程嵌套If语句语法浅析
  3. ASP.NET编程中日期与时间的处理浅析
  4. ASP.NET编程之实现弹窗报警提示浅析
  5. ASP.NET调用存储过程的含义及好处

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...