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

来源:互联网 发布:工信部证书有用吗 知乎 编辑:程序博客网 时间:2024/04/30 20:14

存储过程是保存在数据库上的批次执行的一条或者多条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拖控件,拖完不知道这些控件是怎么产生的,用起来总感觉虚的很。而且不了解操作系统,写出来的代码的性能注定不是很好,瓶颈会很低。我自己在大学

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

原创粉丝点击