C#操作ORACLE数据库示例Word文件下载.docx
《C#操作ORACLE数据库示例Word文件下载.docx》由会员分享,可在线阅读,更多相关《C#操作ORACLE数据库示例Word文件下载.docx(11页珍藏版)》请在冰豆网上搜索。
一、调用一个带输入、输出参数的存储过程
首先,在Oralce中创建存储过程如下:
createorreplaceprocedurescott.GetRecords(name_outoutvarchar2,age_ininvarchar2)asbegin
selectNAMEintoname_outfromscott.testwhereAGE=age_in;
end;
然后,在C颗目xx如下调用:
stringconnectionString="
DataSource=YXZHANG;
UserID=YXZHANG;
Password=YXZHANG”;
stringqueryString="
getrecords"
;
cmd.CommandType=CommandType.StoredProcedure;
cmd.Parameters.Add("
name_out"
OracleType.VarChar,20);
cmd.Parameters["
].Direction=ParameterDirection.Output;
age_in”,21);
cmd.ExecuteNonQuery();
Console.WriteLine("
Nameis:
{0}”,cmd.Parameters["
].Value.ToString());
Theexceptionmessageis:
{0}”,ex.Message.ToString());
}
finally{Console.WriteLine("
End"
);
}」、结:
以上是很平常的调用方法,但是我在做这个示例程序的时候,却不是那么一帆风顺。
这里要指出OracleClient的一个不尽如人意之处,就是对于参数名称,必须和存储过程定义中的参数同名,否则就会报错。
比如将代码中的
“name_ou成为别的名称的话,就会报异常。
但我试着用OleDb代替
OralceClient,却没有这个问题。
不知道在新版本的数据提供程序中会否改进这一点?
二、调用不返回数据的存储过程
createorreplaceprocedureinsertRecord(UserIDinvarchar2,
UserNameinvarchar2,
UserAgeinvarchar2)is
begin
insertintotestvalues(UserID,UserName,UserAge);
Data
ID=YXZHANG;
insertRecord"
UserID"
"
007"
UserName”,"
Dell"
UserAge”,"
40”);
不返回数据的存储过程一般有Delete,Insert,Update等。
虽然它们的SQL语句不同,但是调用方面都是一样的。
只要传入正确的参数,一般不会出什么问题。
不过还是要注意,在使用OralceClient作为数据提供者的时候,参数名称一定要和存储过程定义中的一致!
至于参数添加的顺序倒是无所谓的,因为有参数名称作为区别。
三、IDENTITY^SEQUENCE
SqlServer中,定义一个列为递增列很容易,但我在Oracle中却怎么也找不到设置的方法。
不过查了点资料后知道Oracle中有个叫Sequence的对象,产生一个唯一的序列号,类似于SqlServer中的IDENTITY于是,我做了如下实验:
首先,在Oracle中创建了一个名为TEST_SEQ]Sequence对象,SQL语句如下:
createsequenceTEST_SEQ
minvalue100
maxvalue999
startwith102
incrementby1
nocache;
语法应该是比较易懂的,最小最大值分别用minvalue,maxvalue表示,初始
值是102(这个数字是动态变化的,我创建的时候设的是100,后因插入了2条
数据后就白动增加了2),increment当然就是步长了。
在PL/SQL中可以用test_seq.nextval访问下一个序列号,用test_seq.currval访问当前的序列号。
定义完了Sequence,接下来就是创建一个存储过程InsertRecordWithSequence
--这次我修改了test表的定义,和前面的示例不同。
其中,UserID是P&
createorreplaceprocedureInsertRecordWithSequence(UserIDoutnumber,
UserNameinvarchar2,UserAgeinnumber)is
insertintotest(id,name,age)--插入一条十己录,PK值从Sequece获取values(test_seq.nextval,UserName,UserAge);
/*返回PK值。
注意Dual表的用法*/
selecttest_seq.currvalintoUserIDfromdual;
endInsertRecordWithSequence;
接下来,就是在Cg进行调用了:
InsertRecordWithSequence"
UserID”,OracleType.Number);
Jack"
UserAge”,40);
introwAffected=cmd.ExecuteNonQuery();
{0}行已插入。
”,rowAffected);
插入行的
}ID为:
catch(OracleExceptionex){Console.WriteLine("
Exceptionoccurred!
"
使用Sequece对象可以很容易地创建唯一序列,在存储过程中的调用也十
分方便,只要sequence_name.nextval以及sequence.currval就能得至V下一个以及当前的序列值。
倒是Dual表值得注意。
四、使用DataReader读取返回的结果集
为了让存储过程返回结果集,必须定义一个游标变量作为输出参数。
这和
SqlServer中有着很大的不同!
并且还要用到Oracle中包”(Package的概念,似乎有点繁琐,但熟悉后也会觉得很方便。
关于包”的概念,有很多内容可以参考,在此就不赘述了。
首先,我创建
了一个名为TestPackage0勺包,包头是这么定义的:
createorreplacepackageTestPackageis
typemycursorisrefcursor;
--定义游标变量
procedureGetRecords(ret_cursoroutmycursor);
-症义过程,用游标变量作为返回参数endTestPackage;
包体是这么定义的:
createorreplacepackagebodyTestPackageis
/*过程体*/
procedureGetRecords(ret_cursoroutmycursor)as
openret_cursorforselect*fromtest;
endGetRecords;
endTestPackage;
已经万事具备了,让我们前台调用试试:
TestPackage.GetRecords”;
桩意调用方法
ret_cursor”,OracleType.Cursor);
//注意这里的类型cmd.Parameters["
ret_cursor"
OracleDataReaderdr=cmd.ExecuteReader();
inti=1;
while(dr.Read()){Console.WriteLine("
Record{0}:
i++);
ID:
{0}Name:
{1}Age:
⑵"
,
dr.GetOracleNumber
(0),
dr.GetOracleString
(1),
⑵);
Console.WriteLine();
}dr.Close();
//用完DataReader对象要记得及时关闭
Theexce