[原]ADO.net学习和总结(C#,Oracle)

 

ADO.NetOracle数据库的操作

 

 ADO.Net简介

访问数据库的技术有许多,常见的有一下几种:开放数据库互联(ODBC)、 数据访问对象(DAO)、远程数据对象(RDO)、 ActiveX数据对象(ADO)。我们今天主要要学习ADO.NETOracleClient命名空间中的几个常用对象,用这作为对ADO.NET认识学习的开始。

ADOADO.NET既有相似也有区别,他们都能够编写对数据库服务器中的数据进行访问和操作的应用程序,并且易于使用、高速度、低内存支出和占用磁盘空间较少,支持用于建立基于客户端/服务器和 Web 的应用程序的主要功能。但是ADO使用OLE DB接口并基于微软的COM技术,而ADO.NET拥有自己的ADO.NET接口并且基于微软的.NET体系架构。众所周知.NET体系不同于COM体系,ADO.NET接口也就完全不同于ADOOLE DB接口,这也就是说ADO.NET.NET构架提供了优化的数据访问模型,和基于COMADO是完全两样的数据访问方式。

ADO.NET是一组访问数据源的面向对象的类库。简单的理解,数据源就是数据库,它同时也能够是文本文件、Excel表格或者XML文件。ADO.NET里包括了许多专门用于和数据打交道的对象。下面介绍了一些最常用的对象。这些对象是学习ADO.NET必须了解的。掌握它们后我们将了解使用ADO.NET和数据打交道需要考虑哪些事情。

OracleConnection 对象

要访问一个数据源,你必须先建立一个到它的连接。这个连接里描述了数据库服务器类型、数据库名字、用户名、密码,和连接数据库所需要的其它参数。command对象通过使用connection对象来知道是在哪个数据库上面执行ORACLE命令。


None.gif OracleConnection oracleConn  =   new  OracleConnection();
None.giforacleConn.ConnectionString 
=   " User Id=scott;Password=tiger;
None.gif
                                     Data Source = oracleSN; " ;
None.gif
oracleConn.Open();
None.gif

 

OracleCommand对象

连接数据库后就可以开始想要执行的数据库操作,这个是通过command对象完成,command对象一般被用来发送ORACLE语句给数据库。command对象通过connection对象得知道应该与哪个数据库进行连接。我们既可以用command对象来直接执行ORACLE命令,也可以将一个command对象的引用传递给OracleDataAdapterOracleDataAdapter能包含一系列的command对象,可以处理大量数据。

None.gif public   void  ReadMyData( string  connectionString)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
string queryString = "SELECT EmpNo, DeptNo FROM Scott.Emp";
InBlock.gif    OracleConnection connection 
= new OracleConnection(connectionString)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        OracleCommand command 
= new OracleCommand(queryString, connection);
InBlock.gif        connection.Open();
InBlock.gif        OracleDataReader reader 
= command.ExecuteReader();
InBlock.gif        
try
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
while (reader.Read())
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                Console.WriteLine(reader.GetInt32(
0+ "" + reader.GetInt32(1));
ExpandedSubBlockEnd.gif            }

ExpandedSubBlockEnd.gif        }

InBlock.gif        
finally
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            reader.Close();
ExpandedSubBlockEnd.gif        }

ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}

None.gif

 

OracleDataReader对象

许多数据库操作要求我们仅仅只是需要读取一组数据。这时候就用到了data reader对象。通过data reader对象,我们可以获得从command对象的SELECT语句得到的结果。考虑到性能方面的因素,data reader返回的数据流被设计为只读的、单向的,这将意味着你只能按照一定的顺序从数据流中取出数据。虽然你在这里也获得了性能上的提升,但是缺点也是明显的,不能够操作取回数据,如果需要操作编辑数据,解决的办法是使用DataSet
OracleDataReader提供了几个方法,在读取数据的时候用这些方法可以对数据表中的数据按数据类型进行筛选GetDateTime, GetDouble, GetGuid, GetInt32

DataSet对象

DataSet对象用于表示那些储存在内存中的数据。它包括多个DataTable对象,DataTable就象一个普通的数据库中的表一样,也有行和列,我们甚至能够通过定义表和表之间的关系来创建从属关系。DataSet主要用于管理存储在内存中的数据以及对数据的断开操作。注意,由于DataSet对象能被所有Data Providers(数据源交互的类库)使用,它不需要指定前缀。

OracleDataAdapter对象

某些时候我们只需要读数据,并且你不需要修改它们把更改写回数据源。但是还有这样一些情况为了减少数据库调用的次数,我们把数据缓存在内存中。Data adapter通过断开模型来轻松的实现了后面这种情况的处理。当批量完成的对数据库的读写操作的并将改变写回数据库的时候,data adapter 会填充(fillDataSet对象。data adaapter里包含了connection对象,当对数据源进行读取或者写入的时候,data adapter会自动的打开或者关闭连接。此外,data adapter还包含对数据的SELECT,INSERT,UPDATEDELETE操作的command对象引用。如果我们为DataSet中的每一个table都指定data adapter,它将会帮你处理好所有与连接处理数据库的操作,我们所需要做的仅仅就是告诉data adapter什么时候读取或者写入到数据库。

C# 写一个连接数据库程序的步骤

在程序中要使用 System.Data.OracleClient 命名空间中类的子集来对Oracle数据库操作的步骤:

1  System.Data.OracleClient(用于Oracle Microsoft .NET 框架数据提供程序)的引用添加到项目中。

2   使用 using 指令导入 OracleClient 类中的类型。

using System.Data.OracleClient;

3 创建一个 OracleConnection 对象。
None.gif OracleConnection conn  =   new  OracleConnection( " Data Source=oracledb;User Id=UserID;Password=Password; " );

4 创建一个 OracleCommand 对象。将其 Connection 属性设置为上一 步中创建的连接。将其 CommandText 设置为想对数据库表进行的操作,即 SQL 语句。
None.gif OracleCommand cmd  =   new  OracleCommand();
None.gifcmd.Connection 
=  conn;
None.gifcmd.CommandText 
=   " select * from table " ;
None.gif

5 创建 OracleParameter 对象,并将其添加到 OracleCommand 对象的参数集合中。(如果 CommandText 中有参数,需要创建此对象)
None.gif cmd.Parameters.Add( " reccount " ,OracleType.Number);

6    如果您要浏览操作的结果集,请创建 DataSet DataTable DataReader 。。

7   使用 OracleCommand 对象的一个 Execute 方法执行CommandText中的SQL语句,如下所示:

None.gif conn.Open();
None.gifcmd.ExecuteNonQuery();
None.gifconn.Close();
None.gif

 

Execute方法      说明

ExecuteReader   通过执行能够返回结果集生成 OracleDataReader

ExecuteNonQuery     执行返回受影响的行数。

ExecuteOracleNonQuery 针对OracleCommand.Connection执行SQL语句,返回受影响的行数。

ExecuteScalar    执行一个查询并且返回查询结果集第一行第一列的值作为 .NET 框架数据类型返回。

ExecuteOracleScalar 执行一个查询并且返回查询结果集的第一行第一列的值作为Oracle指定类型 OracleType 数据类型)返回。

 详细操作总结

1.数据库连接有2种:

    第一种:古老的方法(较为死板,不利于灵活操作),即用OracleConnection的类来连接

None.gif string  myOraclestr  = " user id = xal;data source = xal;password = xal " ;
None.gifOracleConnection mycnn 
=   new  OracleConnection(myOraclestr);
None.gifmycnn.open();
None.gif

第二种:新式的方法(使用较为灵活),即利用OracleConnectoinStringBuilder类来连接

None.gif OracleConnectionStringBuilder OcnnStrB  =   new  OracleConnectionStringBuilder();
None.gifOCnnStrB.DataSource 
=   " xal " ;
None.gifOCnnStrB.UserID 
=   " xal " ;
None.gifOCnnStrB.Password 
=   " xal " ;
None.gifOracleConnection myCnn 
=   new  OracleConnection(OCnnStrB.ConnectionString);
None.gifmyCnn.open();
None.gif

 

2. 数据库表的操作   

2.1数据库表的查询、添加、删除和修改。

       第一种:利用OracleDataAdapter的类

None.gif string  Oraclestr  =   " select name from telephonebook  "
None.gifOracleDataAdapter myoadapt 
=   new  OracleDataAdapter(Oraclestr, myConnection);
None.gif

第二种:利用OracleCommand的类

None.gif string  Oraclestr  =   " delete from telephonebook "
None.gifOracleCommand myocmd 
=   new  OracleCommand(Oraclestr, myConnection);
None.gifmyocmd.ExecuteNonQuery();
None.gif

 

       第三种:利用OracleCommandCommandText属性

None.gif  OracleCommand myConnection  =   new  OracleCommand();
None.gif Comm.Connection 
=  myConnection;
None.gif Comm.Transaction 
=  myConnection.BeginTransaction();
None.gif Comm.CommandText 
=   " select * from table " ;
None.gif Comm.ExecuteNonQuery();
None.gif Comm.Transaction.Commit();
None.gif

2.2 数据集的浏览

None.gif string  Oraclestr  =   " select name from telephonebook  " ;
None.gifOracleDataAdapter myoadapt 
=   new  OracleDataAdapter(Oraclestr, myConnection);
None.gifDataTable mydtable 
=   new  DataTable();
None.gifmyoadapt.Fill(mydtable);
None.gif
foreach  (DataRow dr  in  mydtable.Rows)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif     comboBox1.Items.Add(dr[
0].ToString());
ExpandedBlockEnd.gif}

None.gif

 

2.3事务的操作。

           数据库事务是指作为单个逻辑工作单元执行的一系列操作。

设想网上购物的一次交易,其付款过程至少包括以下几步数据库操作:

     更新客户所购商品的库存信息

     保存客户付款信息--可能包括与银行系统的交互

     生成订单并且保存到数据库中

     更新用户相关信息,例如购物数量等等

    正常的情况下,这些操作将顺利进行,最终交易成功,与交易相关的所有数据库信息也成功地更新。但是,如果在这一系列过程中任何一个环节出了差错,例如在更新商品库存信息时发生异常、该顾客银行帐户存款不足等,都将导致交易失败。一旦交易失败,数据库中所有信息都必须保持交易前的状态不变,比如最后一步更新用户信息时失败而导致交易失败,那么必须保证这笔失败的交易不影响数据库的状态--库存信息没有被更新、用户也没有付款,订单也没有生成。否则,数据库的信息将会一片混乱而不可预测。

数据库事务正是用来保证这种情况下交易的平稳性和可预测性的技术。


 

None.gif // 连接数据库并打开
None.gif
string  myConnString  =   " user id=xal;data source=xal2;password=xal "
None.gifOracleConnection myConnection 
=   new  OracleConnection(myConnString);
None.gifmyConnection.Open();
ExpandedBlockStart.gifContractedBlock.gif
dot.gif
InBlock.gif      
//创建事务
InBlock.gif
       OracleTransaction myTransaction = myConnection.BeginTransaction();
InBlock.gif       OracleCommand myocmd 
= new OracleCommand("", myConnection);
InBlock.gif       myocmd.Transaction 
= myTransaction;
InBlock.gif       
try
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif             
//语句块
InBlock.gif
               myTransaction.Commit();
ExpandedSubBlockEnd.gif        }

InBlock.gif        
catch (Exception ex)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif              MessageBox.Show(ex.Message);
InBlock.gif               myTransaction.Rollback();
ExpandedSubBlockEnd.gif        }

InBlock.gif        
finally
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif              myConnection.Close();
ExpandedSubBlockEnd.gif        }

ExpandedBlockEnd.gif     }

None.gif

2.4从数据表中读取图片数据

从数据库中取一个图片数据,用 二进制数组来存储,然后将其显示在指定的控件上。
None.gif byte [] tmpImage  =  ( byte [])curRow[ " Pic " ];
None.gif
//  fileLength是数组的长度(图片的大小)和curImageFormat图片格式。
None.gif
fileLength  =  tmpImage.Length;
None.gifMemoryStream curStream 
=   new  MemoryStream(tmpImage);
None.gifpicPersonel.Image 
=  Image.FromStream(curStream);
None.gifcurImageFormat 
=  picPersonel.Image.RawFormat;
None.gif
 

2.5 命令参数的创建和使用

创建命令参数

None.gif private  OracleParameter CreateOraParam( string  ParamName,  object  ParamValue)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    OracleParameter Result 
= new OracleParameter();
InBlock.gif     Result.ParameterName 
= ParamName;
InBlock.gif     
if (ParamValue != null)
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif           Result.Value 
= ParamValue;
ExpandedSubBlockEnd.gif      }

InBlock.gif      
else
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{
InBlock.gif           Result.Value 
= DBNull.Value;
ExpandedSubBlockEnd.gif      }

InBlock.gif      Result;
ExpandedBlockEnd.gif}

None.gif
这样的话,当要对数据库操作时就可以运用了:
None.gif insertComm.CommandText  =   " insert into TESTADODOTNET (ID) values (:pID) " ;
None.gifinsertComm.Parameters.Add(CreateOraParam(
" pID " , (txtID.Text.Trim()  !=   "" ?  txtID.Text.Trim() :  null ));
None.gif

转载于:https://www.cnblogs.com/salonliudong/archive/2007/05/11/743284.html

猜你喜欢

转载自blog.csdn.net/weixin_34212762/article/details/93290935
今日推荐