用C#对ADO.NET数据库完成简单操作的方法

数据库访问是程序中应用最普遍的部分。随着C#和ADO.NET的引入,这种操作变得更简单。这篇文章将示范四种最基础的数据库操作。 
  ● 读取数据。其中包括多种数据类型:整型,字符串,日期型。 
  ● 写数据。如读数据一样,我们也需要写入多种类型的数据。这可以通过SQL语句来完成。 
  ● 更新或修改数据。我们将再次用到SQL语句。 
  ● 删除数据。用SQL实现。 
  上述的操作都要基于Microsoft Access 2000数据库,但是,我们要对连接字符串进行简单的修改才能使用SQL或其他ADO数据。 
  开始操作 
  在使用ADO类之前,我们将把ADO.NET的命名空间和一些常用数据类包括进来。把下面的代码加入到你想进行数据库操作的地方。它的具体位置应该是命名空间行之后,类声明之前。 
using System.Data; // State variables 
using System.Data.ADO; // Database 
using System.Globalization; // Date  
  你或许还要向System.Data命名空间添加参数,这取决于工程的类型需要。你所添加的代码的编译信息会提醒你这一点。添加System.Data命名空间的操作: 
  ● 右键点击Solution explorer--参数选项; 
  ● 选择添加参数; 
  ● 选择.NET框架栏; 
  ● 双击System.data.dll条目; 
  ● 选择OK; 
  ● System.data应该出现在Solution explorer的参数列表中了。 
  由于在多数操作中都会使用连接字符串,所以我建议你将它包含在使用的类中。 
  注意:程序中数据库文件的路径可能和下面不一样: 
//Attributes 
public const string DB_CONN_STRING = 
"Driver={Microsoft Access Driver (*.mdb)}; "+ 
"DBQ=D:\\CS\\TestDbReadWrite\\SimpleTest.mdb";  
  读取数据 
  现在的操作就比较有趣了。读是通过ADODataReader类完成的(参看Chris Maunder的文章"The ADO.NET ADODataReader CLASS" 以了解更多)。读的操作步骤如下: 
  ● 用ADO连接打开数据库 
ADOConnection conn = new ADOConnection(DB_CONN_STRING); 
conn.Open();  
  ● 创建一个SQL语句来确认要获取的数据。这条命令执行后返回一个ADODataReader对象。注意Execute方法中的OUT关键字。这是C#中传递参数的方式。 
ADODataReader dr; 
ADOCommand cmd = new ADOCommand( "Select * FROM Person", conn ); 
cmd.Execute( out dr);  
  ● 循环遍历ADODataReader中的每条记录,直到完成。注意:数据被作为字符串直接返回。字段名显示了要读取的字段。 
while( dr.Read() ) 

System.Console.WriteLine( dr["FirstName"] ); 
}  
  ● 清除 
  但是,作为优秀的程序员我们应该将代码放在try/catch/finally 中,确保我们能够控制所有意外。 
try 

.... the database operations ... 

catch( Exception ex ) 

System.Console.WriteLine( "READING:" ); 
System.Console.WriteLine( " ERROR:" + ex.Message ); 
System.Console.WriteLine( " SQL :" + sSqlCmd ); 
System.Console.WriteLine( " Conn.:" + DB_CONN_STRING ); 

finally 

// Close the connection 
if( conn.State == DBObjectState.Open ) 
conn.Close(); 
}  
  读取不同的数据类型 
  ["stuff"]通常可以返回某个类型的字符串。但是要获取一个整型或 DateTime对象,就需要列出这些数据。以一个简单的例子或是ADODataReade内建的很多例子中的一个就可以说明。例如: 
int nOrdinalAge = dr.GetOrdinal( "Age" ); 
int nAge = dr.GetInt32( nOrdinalAge ); 
DateTime tUpdated = (DateTime)dr["Updated"]; 
  注意通过名字定位GetOrdinal字段的用法。如果字段是空的(没有填入值),上面的代码会引发一个异常。这种情况下我们用IsNull方法检验数据是否存在。 
int nOrdinalAge = dr.GetOrdinal( "Age" ); 
if( dr.IsNull( nOrdinalAge ) ) 

System.Console.WriteLine( " Age : Not given!" ); 

else 

int nAge = dr.GetInt32( nOrdinalAge ); 
System.Console.WriteLine( " Age : " + nAge );  
  插入,修改,删除和其他SQL命令 
  插入,修改,和删除用SQL语句很容易实现。下面的代码通过一个SQL命令插入一条记录: 
// SQL command 
String sSQLCommand = "Insert INTO Person (Age, FirstName, 
Description, Updated) " + 
"VALUES( 55, 'Bob', 'Is a Penguin', 
'2001/12/25 20:30:15' );"; 
// Create the command object 
ADOCommand cmdAdder = new ADOCommand( 
sSQLCommand, 
DB_CONN_STRING); 
cmdAdder.ActiveConnection.Open(); 
// Execute the SQL command 
int nNoAdded = cmdAdder.ExecuteNonQuery(); 
System.Console.WriteLine( "\nRow(s) Added = " + nNoAdded + "\n" );  
  注意:try/catch并未出现在上述例子中,实际上是需要写的。 
  插入 
  上述代码通过一条SQL语句插入一条记录。这条命令稍后执行。命令格式中需要注意的是: 
  ● 数值直接赋值,不同单引号('); 
  ● 字符串必须用单引号括起来 ('blah'); 
  ● 字符串中不能包含任何单引号或是双引号; 
  ● 日期和时间都要以国际格式包括在单引号中。('YYYYY/MM/DD HH:MM:SS') 
  修改 
  Update命令指示了要被修和已做修改的记录。ExecuteNonQuery()返回的值显示变化的纪录的数目,这样如果在表格中有5个Peter那它就会返回5。 
  String sSQLCommand = "Update Person SET Age = 27 Where FirstName = 'Peter'"; 
  删除 
  Delete命令显示要被删除的纪录。这可能会是几条。ExecuteNonQuery()返回的值显示变化的纪录的数目,这样如果表中有2个Bobo就返回2。这两个Bobo都会被删除。 
  String sSQLCommand = "Delete FROM Person Where FirstName = 'Bobo'"; 
  关于样例程序 
  样例是个简单的控制程序,它执行Microsoft Access数据库中提供的所有操作。在Visual Studio.NET IDE将TestDbReadWrite.csproj 作为工程文件打开就可以编译它。在MainConsole.cs中改变DB_CONN_STRIN的值,让其指向SimpleTest.mdb,编译它。

(0)

相关推荐

  • C#动态创建Access数据库及密码的方法

    以前工作中需要全新的Access数据库,可以复制数据库,也可以把新的数据库放到资源里面,用新数据库的时候释放出来,都感觉不爽,还是动态生成心理舒服. 生成数据库要使用ADO,首先添加引用. using System.IO; using System.Data.OleDb; //连接Access数据库 using ADOX; //引用COM:Microsoft ADO Ext. 2.8 for DDL and Security //添加引用:Microsoft ActioveX Data Obje

  • C#动态创建Access数据库及表的方法

    本文实例讲述了C#动态创建Access数据库及表的方法.分享给大家供大家参考. 具体实现方法如下: 复制代码 代码如下: //添加两个com组件引用 //Microsoft ADO Ext. 2.8 for DDL and Security //Microsoft ActiveX Data Objects 2.8 Library using System; using System.Collections.Generic; using System.Linq; using System.Text

  • asp.net(C#) Access 数据操作类

    复制代码 代码如下: using System; using System.Configuration; using System.Data; using System.Data.OleDb; using System.Xml; using System.Collections; namespace Website.Command { /// <summary> /// WSplus 的摘要说明. /// </summary> public class AccessClass :

  • C#使用Ado.Net更新和添加数据到Excel表格的方法

    本文实例讲述了C#使用Ado.Net更新和添加数据到Excel表格的方法.分享给大家供大家参考.具体分析如下: 微软NET提供了一个交互的方法,通过使用ADO.NET与Microsoft Office程序.内置的OLEDB提供可以用来操纵Excel的.xls电子表格.您可以在Excel中创建一个命名的范围确定表名,我们还需要列标题,如果电子表格中不包含列标题,那么你就需要将它们添加. 如何在Excel中创建一个命名的范围? 随着电子表格打开,选择你希望包括数据查询,包括标题. 选择"插入&quo

  • ADO.NET 读取EXCEL的实现代码((c#))

    // 连接字符串 复制代码 代码如下: // 连接字符串                     string xlsPath = Server.MapPath("~/app_data/somefile.xls"); // 绝对物理路径         string connStr = "Provider=Microsoft.Jet.OLEDB.4.0;" +                         "Extended Properties=Exc

  • c#连接access数据库操作类分享

    1.配置web.config文件:配置数据库连接参数(根据实际情况设置数据库路径和密码) 复制代码 代码如下: <configuration><appSettings/><connectionStrings><add name="ConnectionString" connectionString="PRovider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\keleyi\App_Data\db.m

  • C#操作Access通用类实例

    本文实例讲述了C#操作Access通用类.分享给大家供大家参考.具体如下: using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using Syst

  • C# Access数据库增删查改的简单方法

    引用集:using System.Data.OleDb; 复制代码 代码如下: static string exePath = System.Environment.CurrentDirectory;//本程序所在路径 //创建连接对象OleDbConnection conn = new OleDbConnection("provider=Microsoft.Jet.OLEDB.4.0;data source=" + exePath + @"\文件名.mdb");

  • C#使用Ado.net读取Excel表的方法

    本文实例讲述了C#使用Ado.net读取Excel表的方法.分享给大家供大家参考.具体分析如下: 微软NET提供了一个交互的方法,通过使用ADO.NET与Microsoft Office程序.可以使用内置的OLEDB来访问Excel的XLS表格.下面的例子演示了如何在C#编程读取Excel工作表.需要引用System.Data.OleDb库 using System; using System.Data.OleDb; namespace ConsoleApplication1 { class P

  • 利用C#远程存取Access数据库

    一. 技术要点 我们都知道Windows应用程序在运行时会启动一个进程,其总包括若干线程,不同的进程之间通信是开发分布式应用程序所必需的,传统上,这不仅需要深入了解通信流两端上进程的对象,而且还要深入了解低级别协议的宿主.应用程序编程接口以及配置工具等.总之,它是一项需要大量专业知识和经验的复杂任务. 幸好.Net为我们提供了远程处理功能,它所提供的通信方法可以快速而方便地完成上述建立通信的任务.因此,无论是需要快速开发 Web 应用程序,还是要花费更多时间生成关键的企业范围的应用程序,.NET

  • C#使用ADO.Net部件来访问Access数据库的方法

    数据库的访问是所有编程语言中最重要的部分,C#提供了ADO.Net部件用于对数据库进行访问.我们将从最简单易用的微软Access数据库入手讨论在C#中对数据库的访问. C#中的Connection对象和Command对象与Access类似,但在这里我们还将使用其另一个与RecordSet类似的被称作ADODataReader的对象,它负责处理与查询有关的RecordSet对象. 首先,必须使用微软的Access创建一个数据库.运行Access,创建一个数据库,但不要创建任何表(我们将在下面的程序

随机推荐