存储过程是保存在数据库上的批次执行的一条或者多条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拖控件,拖完不知道这些控件是怎么产生的,用起来总感觉虚的很。而且不了解操作系统,写出来的代码的性能注定不是很好,瓶颈会很低。我自己在大学
就没好好学习那些基础,出来也是直接接触的上层代码,大家觉得要不要再回头就啃基础。迷茫中。。求大神解惑