庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>数 据 库>Oracle>经验技巧>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

Oracle操作相关 (二)

 作者:本站收集   日期:2005-3-18
字号选择〖 〗/ 双击滚屏 单击停止   

         cn.Close();        //DataReader     }

     catch( OracleException ex )

     {

         Console.WriteLine("Exception occurred!");

         Console.WriteLine("The exception message is:{0}",ex.Message.ToString());

     }

     finally

     {

         Console.WriteLine("------------------End-------------------");

     }

 

请看结果:

  Name:Tony       Age:23

  Name:Jack       Age:40

 

小结:

    包是Oracle特有的概念,Sql Server中找不到相匹配的东西。在我看来,包有点像VC++的类,包头就是.h文件,包体就是.cpp文件。包头只负责定义,包体则负责具体实现。如果包返回多个游标,则DataReader会按照您向参数集合中添加它们的顺序来访问这些游标,而不是按照它们在过程中出现的顺序来访问。可使用DataReaderNextResult()方法前进到下一个游标。

 

ADO.NET舍弃了原来ADORecordSet的概念,而使用全新的DataSet来替代。DataSet可以提供更加强大的功能!有了前面的基础,利用ADO.NETOralce返回DataSet也是非常简单的。主要思想就是用DataAdapter接收返回的游标,再用DataAdapterFill()方法填充数据集。在下面的例子中,我仍用了前一个例子中建好的TestPackage包。

 

下面是前台调用主要代码:

connectionString = "Data Source=YXZHANG;User ID=YXZHANG;Password=YXZHANG";

     string queryString = "TestPackage.GetRecords";

     OracleConnection cn = new OracleConnection(connectionString);

     OracleCommand cmd = new OracleCommand(queryString,cn);

     cmd.CommandType = CommandType.StoredProcedure;

     cmd.Parameters.Add("ret_cursor",OracleType.Cursor);

     cmd.Parameters["ret_cursor"].Direction = ParameterDirection.Output;

    

     try

     {

         cn.Open();

         OracleDataAdapter da = new OracleDataAdapter(cmd);

         DataSet ds = new DataSet();

         da.Fill(ds,"TestTable");

         cn.Close();

         for( int i = 0;i <= ds.Tables["TestTable"].Rows.Count-1;i++ )

         {

              string id = ds.Tables["TestTable"].Rows[i]["ID"].ToString();

              string name = ds.Tables["TestTable"].Rows[i]["NAME"].ToString();

              string age = ds.Tables["TestTable"].Rows[i]["AGE"].ToString();

              Console.WriteLine("Record {0}:",i+1);

              Console.WriteLine("ID:{0}\tName:{1}\tAge:{2}\n",id,name,age);

         }

     }

     catch( OracleException ex )

     {

         Console.WriteLine("Exception occurred!");

         Console.WriteLine("The exception message is:{0}",ex.Message.ToString());

     }

     finally

     {

         Console.WriteLine("------------------End-------------------");

     }

小结:

    程序调用后的结果和刚才用DataReader调用的结果一样。这里只说明怎样利用ADO.NET调用Oracle存储过程,以及怎样填充至数据集中。至于怎样操纵DataSet,不是本文的讨论范围。有兴趣的读者可以参考MSDN以及相关书籍。

 

通常用DataAdapter取回DataSet,将会对DataSet进行一些修改,继而更新数据库(如果只是为了获取数据,微软推荐使用DataReader代替DataSet)。然而,通过存储过程更新数据库,并不是那么简单,不能简单地通过DataAdapterUpdate()方法进行更新。必须手动为DataAdapter添加InsertCommand, DeleteCommand, UpdateCommand,因为存储过程对这些操作的细节是不知情的,必须人为给出。

为了达成这个目标,我完善了之前的TestPackage包,包头如下:

    or replace package TestPackage is

     type mycursor is ref cursor;

     procedure UpdateRecords(id_in in number,newName in varchar2,newAge in number);

     procedure SelectRecords(ret_cursor out mycursor);

     procedure DeleteRecords(id_in in number);

     procedure InsertRecords(name_in in varchar2, age_in in number);

TestPackage;包体如下:

or replace package body TestPackage is
    procedure UpdateRecords(id_in in number, newName in varchar2, newAge  in number) as
    begin
     update test set age = newAge, name = newName where id = id_in;
    end UpdateRecords;

    procedure SelectRecords(ret_cursor out mycursor) as
    begin
       open ret_cursor for select * from test;
    end SelectRecords;

    procedure DeleteRecords(id_in in number) as
    begin
       delete from test where id = id_in;
    end DeleteRecords;

    procedure InsertRecords(name_in in varchar2, age_in in number) as
    begin
       insert into test values (test_seq.nextval, name_in, age_in);

是一个已建的Sequence对象,请参照前面的示例

InsertRecords;
    end TestPackage;
前台调用代码如下,有点繁琐,请耐心阅读:

     string connectionString = "Data Source=YXZHANG;User ID=YXZHANG;Password=YXZHANG";

     string queryString = "TestPackage.SelectRecords";

     OracleConnection cn = new OracleConnection(connectionString);

     OracleCommand cmd = new OracleCommand(queryString,cn);

     cmd.CommandType = CommandType.StoredProcedure;

     cmd.Parameters.Add("ret_cursor",OracleType.Cursor);

     cmd.Parameters["ret_cursor"].Direction = ParameterDirection.Output;

    

     try

     {

          cn.Open();

          OracleDataAdapter da = new OracleDataAdapter(cmd);

          DataSet ds = new DataSet();

          da.Fill(ds,"TestTable");

          cn.Close();

          int count = ds.Tables["TestTable"].Rows.Count;

         

          /*          Console.WriteLine("Old Records is:");

          for( int i = 0;i <= count - 1;i++ )

         {

              string id = ds.Tables["TestTable"].Rows[i]["ID"].ToString();

              string name = ds.Tables["TestTable"].Rows[i]["NAME"].ToString();

              string age = ds.Tables["TestTable"].Rows[i]["AGE"].ToString();

              Console.WriteLine("Record {0}:",i+1);

              Console.WriteLine("ID:{0}\tName:{1}\tAge:{2}\n",id,name,age);

         }

        

         da.SelectCommand = cmd;     //         OracleCommand updateCmd = new OracleCommand("TestPackage.UpdateRecords",cn);

         updateCmd.CommandType = CommandType.StoredProcedure;

         updateCmd.Parameters.Add("id_in",OracleType.Number,3,"ID");

         updateCmd.Parameters.Add("newName",OracleType.VarChar,20,"NAME");

         updateCmd.Parameters.Add("newAge",OracleType.Number,3,"AGE");

         da.UpdateCommand = updateCmd;        //         OracleCommand deleteCmd = new OracleCommand("TestPackage.DeleteRecords",cn);

         deleteCmd.CommandType = CommandType.StoredProcedure;

         deleteCmd.Parameters.Add("id_in",OracleType.Number,3,"ID");

         da.DeleteCommand = deleteCmd;        //         OracleCommand insertCmd = new OracleCommand("TestPackage.InsertRecords",cn);

          insertCmd.CommandType = CommandType.StoredProcedure;

         insertCmd.Parameters.Add("name_in",OracleType.VarChar,20,"NAME");

         insertCmd.Parameters.Add("age_in",OracleType.Number,3,"AGE");

         da.InsertCommand = insertCmd;        //         DataTable newTable = ds.Tables["TestTable"];

        

         /*         newTable.Rows[0]["AGE"] = 22;

         newTable.Rows[0]["NAME"] = "John";

        

         /*         newTable.Rows[2].Delete();

         /*         DataRow newRow = newTable.NewRow();

         newRow["NAME"] = "Bob";

         newRow["AGE"] = 99;

         newTable.Rows.Add(newRow);

         cn.Open();

         da.Update(newTable);        //

         newTable.Clear();            //         da.Fill(newTable);           //

         cn.Close();

         /*         Console.WriteLine("New Records is:");

         for( int i = 0;i <= newTable.Rows.Count - 1;i++ )

         {

              string id = newTable.Rows[i]["ID"].ToString();

              string name = newTable.Rows[i]["NAME"].ToString();

              string age = newTable.Rows[i]["AGE"].ToString();

              Console.WriteLine("Record {0}:",i+1);

              Console.WriteLine("ID:{0}\tName:{1}\tAge:{2}\n",id,name,age);

         }

     }

     catch( OracleException ex )

     {

          Console.WriteLine("Exception occurred!");

          Console.WriteLine("The exception message is:{0}",ex.Message.ToString());

     }

     finally

     {

         Console.WriteLine("------------------End-------------------");

}

 

运行结果如下:

  Name:Tony       Age:23

  Name:Jack       Age:34

  Name:newAdd     Age:100

  Name:John       Age:22

  Name:Jack       Age:34

  Name:Bob        Age:99

小结:

使用Update()方法更新数据库是非常有用的,但是只局限于单个表,对于表连接的情况,还是直接用OracleCommandExcuteNonQuery()方法去执行更新操作比较方便。

 

.NET中利用ADO.NET调用Oralce9i中的存储过程,函数,包等,可以提高效率,也能完成一些复杂的业务逻辑。然而调用Oracle存储过程和Sql Server中有着很大不同,最需要明确的一个思想就是:在Oracle的过程中,所有返回值必须以输出参数的形式出现。在Oracle中,要返回一个结果集,就必须把REF CURSOR作为返回参数,因此就要用到包。包类似于C++中的类,封装了一些全局变量、常量和函数,在函数中又可以有自己的私有变量。通过返回给应用程序的游标,应用程序就可以用DataReader或者DataAdapter接收它,进而做一些处理。还还可以用DataAdapterUpdate()方法更新数据库,当然它需要你给出更新数据库的一些操作(为其定义处理过程)。

由于笔者是边学边写,以上示例不免有些不妥之处,请多多指教!

上一篇:Oracle操作相关 (一)    下一篇:oracle初始化参数设置  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-3-18
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿