在.net中如何把调用存储过程代码写入数据连接层中

发布时间: 2007-05-21 09:40    作者: 未知    来源: 未知    浏览:    评论

Oracle方面

1.创建Oracle过程存储

create or replace procedure proce_test(paramin in varchar2,paramout out varchar2,paraminout in out varchar2)
as
varparam varchar2(28);
begin
varparam:=paramin;
paramout:=varparam|| paraminout;
end;



2.测试过程存储

declare
param_out varchar2(28);
param_inout varchar2(28);
begin
param_inout:='ff';
proce_test('dd',param_out,param_inout);
dbms_output.put_line(param_out);
end;



测试结果:ddff




C#方面



1.创建界面



类型
对象名
Text属性值

Button
Button1
调用

Label
Label1
A:

Label
Label2
B:

Label
Label3
input

Label
Label4
inputoutput

Label
Label5


TextBox
TextBox1


TextBox
TextBox2





2.显示代码

(1) 在WebForm4.aspx.cs文件

添加字段 private OraOprater mOra=null; //OraOprater 是数据连接层的类

在界面上双击“调用”按钮,编写如下代码:

private void Button1_Click(object sender, System.EventArgs e)

{

mOra=new OraOprater();

Label5.Text=mOra.SpExeFor(TextBox1.Text,TextBox2.Text); //调用存储过程的方法

}



(2) 在数据连接层中的代码(OraOprater.cs)


引用Oracle组件

using System;

using System.Data;

using System.Data.OracleClient;



namespace WebApplication4

{

public class OraOprater

{

private OracleConnection conn=null;

private OracleCommand cmd=null;



public OraOprater()

{

string mConn="data source=ora9i.ora.com;user id=ora;password=ora"; //连接数据库

conn=new OracleConnection(mConn);

try

{

conn.Open();

cmd=new OracleCommand();

cmd.Connection=conn;

}

catch(Exception e)

{

throw e;

}

}



public string SpExeFor(string m_A,string m_B)

{


//存储过程的参数声明
OracleParameter[] parameters={

new OracleParameter("paramin",OracleType.VarChar,20),

new OracleParameter("paramout",OracleType.VarChar,20),

new OracleParameter("paraminout",OracleType.VarChar,20)

};

parameters[0].Value=m_A;

parameters[2].Value=m_B;

parameters[0].Direction=ParameterDirection.Input;

parameters[1].Direction=ParameterDirection.Output;

parameters[2].Direction=ParameterDirection.InputOutput;

try

{

RunProcedure("proce_test",parameters);

return parameters[1].Value.ToString();

}

catch(Exception e)

{

throw e;

}

}



private void RunProcedure(string storedProcName,OracleParameter[] parameters)

{

cmd.CommandText=storedProcName;//声明存储过程名

cmd.CommandType=CommandType.StoredProcedure;

foreach(OracleParameter parameter in parameters)

{

cmd.Parameters.Add(parameter);

}

cmd.ExecuteNonQuery();//执行存储过程

}

}

}

Smile Big Smile Surprise Stick out tongue Wink Sad Tongue Tied Indifferent Crying Embarrassed Cool Angry Angel Devil [8-|] [:#] [:-*] [:^)] [<:o)] [|-)] Yes Beer Left Hug Music Star Time Snail Pizza Automobile Umbrella Computer Storm [mo] [8o|] [^o)] [+o(] [*-)] [8-)] Coffee No Drinks [Z] Right Hug Cake Broken Heart Gift Wilted Flower Movie Dog Idea Sleep Email Travel Paradise
呢称:

加粗 斜体 下划线 链接 图片 代码 邮件地址 引用 列表

最多只能输入100个字符

Tags

SQL 数据库 asp.net C# XML 控件 .NET教程 程序 事件 数据 安全 代码 Server 客户端 验证 数据库专栏 接口 文件 Oracle DataSet 函数 DataGrid 问题 .net return C#语言 JavaScript 服务 IIS 对象 语句 windows 继承 时间 web.config 设计 开发 参数 变量 解决 字符 ADO.net 环境 VB.Net语言 web 异常 工具 服务器 计算 实例 OLEDB Application VB Word WebService insert asp net 安装 记录

精华推荐

更多

精品下载

更多