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拖控件,拖完不知道这些控件是怎么产生的,用起来总感觉虚的很。而且不了解操作系统,写出来的代码的性能注定不是很好,瓶颈会很低。我自己在大学
就没好好学习那些基础,出来也是直接接触的上层代码,大家觉得要不要再回头就啃基础。迷茫中。。求大神解惑
- ADO.NET(五) 调用存储过程(oracle为例)
- ADO.NET调用存储过程
- ADO.NET调用存储过程
- ado.net oledb 调用oracle存储过程返回结果集
- [.NET]ADO.NET调用存储过程
- [.NET]ADO.NET调用存储过程
- [.NET]ADO.NET调用存储过程
- 用ADO.NET调用存储过程
- ado.net执行oracle 存储过程
- ado.net执行oracle 存储过程
- ado.net执行oracle 存储过程
- 数据库连接+SQL语句+存储过程+ADO.Net调用存储过程
- .net 调用Oracle存储过程
- .net 调用Oracle存储过程
- .net 调用Oracle存储过程
- ado调用存储过程
- ado调用存储过程
- ADO.NET调用存储过程,过程比较全
- ubuntu 安装 搜狗输入法
- 经纬度的最简单获得方法
- iOS网络编程-MBProgressHUD等待指示器
- 手机刷机,FastBoot,S-OOF,SPL
- 全局程序集缓存(GAC)
- ADO.NET(五) 调用存储过程(oracle为例)
- iOS网络编程-ASIHTTPRequest小例子-数据请求队列
- Android UI自定义Spinner下拉框(用popuwindow实现)
- iOS网络编程-ASIHTTPRequest异步请求
- Android学习笔记:文件读取与ListView
- 链表
- Hadoop1.2.1源码解析系列:JobTracker(一)——JobTracker初始化
- 词干提取(stemming)和词形还原(lemmatization)
- linux下配置JAVA常用的编程环境