ADO.NET(五) 调用存储过程(oracle为例)

存储过程是保存在数据库上的批次执行的一条或者多条SQL语句,存储过程和函数相似,他们都是良好的逻辑封装体

可以接受传入和传出参数,存储过程有很多优点。

1、更易于维护

你可以优化存储过程中的命令而不用重新编译应用程序。

2、可以更安全的使用数据库

可以让用于执行ASP.NET代码的windows账号有使用某些存储过程的权限但是不可以访问基表。

3、可以提升性能

因为存储过程是多条语句的集合体,访问一次数据库就能做很多事情。

下面看一个例子:

首先我们写一个简单的存储过程有传入参数有传出参数,

create or replace 
procedure Test1(v_t1 varchar2,v_t2 varchar2,v_res out varchar2)
 is 
begin
  insert into mytest VALUES(SQ_TEST.NEXTVAL,v_t1);
  insert into mytest values(to_char(sq_test.nextval),v_t2);
  v_res:=to_char(sql%rowcount);
  exception when others then 
  v_res := '0';
end Test1;
这个过程很简单就新增两条数据,然后传出一个影响行数。

然后看下ado.net如何操作oracle的存储过程,链接数据库的方法就不多做介绍:

 try
            {
                o_Dt = new DbTest();
                //打开链接
                o_Dt.GetConn.Open();
                o_Comm=new OracleCommand("TEST1",o_Dt.GetConn);
                //将命令类型设定为存储过程
                o_Comm.CommandType=CommandType.StoredProcedure;
                //给参数复制并制定参数类型,传入参数可以不用执行 默认
                OracleParameter[] paras ={
                    new OracleParameter("v_t1", OracleDbType.Varchar2,50),
                    new OracleParameter("v_t2", OracleDbType.Varchar2,50),
                    new OracleParameter("v_res", OracleDbType.Varchar2,50)
                };
                paras[0].Value = "value1";
                paras[1].Value = "value2";
                paras[2].Direction = ParameterDirection.Output;
                paras[0].Direction = ParameterDirection.Input;
                o_Comm.Parameters.AddRange(paras);
                o_Comm.ExecuteNonQuery();
                //抓取传出参数
                string res = paras[2].Value.ToString();
                Response.Write(res);
//重新绑定数据。这个就是执行了下查询然后绑定到gridview的方法
                BindTest();
            }catch(Exception ex)
            {
                Response.Write(ex.Message);
            }
            finally
            {
                //关闭连接资源
                o_Dt.GetConn.Close();
            }
其实很简单里面有详细的注释,微软已经给我们封装好了很多方法。效果图:



有人说学编程应该从c/c++开始学起,然后学习数据结构。操作系统,因为那些语言更接近系统,理解了这些然后再学习.net,java这些高级语言就会轻松很多。而不是直接上来就学习asp.net拖控件,拖完不知道这些控件是怎么产生的,用起来总感觉虚的很。而且不了解操作系统,写出来的代码的性能注定不是很好,瓶颈会很低。我自己在大学

就没好好学习那些基础,出来也是直接接触的上层代码,大家觉得要不要再回头就啃基础。迷茫中。。求大神解惑

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值