当前位置: 首页 > 编程笔记 >

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

宇文勇
2023-03-14
本文向大家介绍C#使用ADO.Net部件来访问Access数据库的方法,包括了C#使用ADO.Net部件来访问Access数据库的方法的使用技巧和注意事项,需要的朋友参考一下

数据库的访问是所有编程语言中最重要的部分,C#提供了ADO.Net部件用于对数据库进行访问。我们将从最简单易用的微软Access数据库入手讨论在C#中对数据库的访问。

C#中的Connection对象和Command对象与Access类似,但在这里我们还将使用其另一个与RecordSet类似的被称作ADODataReader的对象,它负责处理与查询有关的RecordSet对象。

首先,必须使用微软的Access创建一个数据库。运行Access,创建一个数据库,但不要创建任何表(我们将在下面的程序中创建表。),保存创建的数据库。

打开控制面板中的ODBC图标,点击System DNS标签,依次选择Add>Microsoft Access,并点击Finish按钮。在拉下来的对话框中输入数据源的名字,比如是mymdb,然后创建数据源,双击OK按钮。

在下面的程序中,我们将创建一个表,并在其中插入一些值。

程序非常地简单和直观。在Main()函数中,ADOConnection对象将数据源的名字取到构造器中,然后使用ADOConenction的Open()方法打开该连接。

在连接建立后,程序将创建包含二个字段的表a1,其中字段name的类型为字符型,vno的类型为整型。Create table命令已经放在ADOCommand的构造器中,ExecuteNonQuery()方法用于执行这一查询,该方法不会返回任何记录集。同样,Insert和Delete查询也可以放到ADOCommand的Constructor中,因此可以象在VB中那样传递任何SQL查询。

ADODataReader是新出现的,它是本段程序中主要的对象,负责处理ADOCommand返回的记录集。使用xecute()方法,就可以看到从数据库中返回的数据。ADODataReader的Read()方法则返回布尔型的值,TRUE标志着数据在ADODataReader对象中,而且将当前指针移动到了ADODataReader对象的下一条记录上。

使用Visual Studio.Net 编译下面的程序代码。 

 namespace database1 
 { 
 using System; 
 using System.Data.ADO; 
  
 public class Class1 
 { 
 public Class1() 
 { 
 // 
 // 在这里添加Constructor的逻辑 
 // 
 } 
  
 public static int Main(string[] args) 
 { 
 try 
 { 
 ADOConnection s = new ADOConnection("Data Source=mymdb"); 
 s.Open(); 
 Console.WriteLine("Connection Established"); 
  
 //创建表 
 Console.Write("Want to Create a Table?(y/n) "); 
 string ch = Console.ReadLine(); 
 if (ch == "y") 
 { 
 ADOCommand CreateTable = new ADOCommand("Create Table a1(vno integer,name char(20))", s); 
 CreateTable.ExecuteNonQuery(); 
 Console.WriteLine("AOCommand Executed / Table Created"); 
 } 
   
 //在表中插入值 
 Console.Write("Want to Insert Some values in a Table?(y/n) "); 
 ch = Console.ReadLine(); 
 if (ch == "y") 
 { 
 ADOCommand InsTable = new 
 ADOCommand("insert into a1 values(1, 'hi')", s); 
  
 InsTable.ExecuteNonQuery(); 
 Console.WriteLine("Values Inserted"); 
 } 
  
 //删除整个表 
 Console.Write("Want to Delete All Records Present in the Table?(y/n) "); 
 ch = Console.ReadLine(); 
 if (ch == "y") 
 { 
 ADOCommand DeleteTable = new ADOCommand("Delete from a1", s); 
 DeleteTable.ExecuteNonQuery(); 
 Console.WriteLine("All Records Deleted From the Table"); 
 } 
  
 //看所有记录 
 Console.Write("Want to See all the Records Present in the Table /Database (y/n)? "); 
 ch = Console.ReadLine(); 
 if (ch == "y") 
 { 
 ADOCommand AllRecs = new ADOCommand("select * from a1", s); 
 ADODataReader r; 
 AllRecs.Execute(out r); 
 while(r.Read()) 
 { 
 for(int i=0; i < r.FieldCount;i++) 
 { 
 Console.Write(r.GetValue(i)+ " "); 
 } 
 Console.WriteLine(); 
 } 
 Console.WriteLine("All Records Displayed"); 
 r.Close(); 
 } 
  
 s.Close(); 
 Console.ReadLine(); 
 } 
 catch(System.Exception e) 
 { 
 Console.WriteLine(e.ToString()); 
 Console.ReadLine(); 
 } 
  
 return 0; 
 } // Main函数结束 
 } // Class结束 
 }// 名字空间结束

以上就是 在C#中使用ADO.Net部件来访问Access数据库的过程,希望对大家的学习有所帮助。

 类似资料:
  • 本章将教您如何访问Perl脚本中的数据库。 从Perl 5开始,使用DBI模块编写数据库应用程序变得非常容易。 DBI代表Perl的Database Independent Interface ,这意味着DBI在Perl代码和底层数据库之间提供了一个抽象层,允许您非常轻松地切换数据库实现。 DBI是Perl编程语言的数据库访问模块。 它提供了一组方法,变量和约定,提供了一致的数据库接口,与所使用的

  • 应用程序与数据库通信,首先,检索存储在那里的数据并以用户友好的方式呈现,其次,通过插入,修改和删除数据来更新数据库。 Microsoft ActiveX Data Objects.Net(ADO.Net)是一个模型,是.Net框架的一部分,由.Net应用程序用于检索,访问和更新数据。 ADO.Net对象模型 ADO.Net对象模型只不过是通过各种组件的结构化流程。 对象模型可以用图形描述为 - 驻

  • ADO.NET提供了前端控件和后端数据库之间的桥梁。 ADO.NET对象封装了所有数据访问操作,控件与这些对象交互以显示数据,从而隐藏了数据移动的细节。 下图显示了ADO.NET对象: DataSet类 数据集表示数据库的子集。 它没有与数据库的连续连接。 要更新数据库,需要重新连接。 DataSet包含DataTable对象和DataRelation对象。 DataRelation对象表示两个表

  • ASP.NET允许访问和使用以下数据源: 数据库(例如,Access,SQL Server,Oracle,MySQL) XML文档 业务对象 平面文件 ASP.NET隐藏了复杂的数据访问过程,并提供了更高级别的类和对象,通过它们可以轻松访问数据。 这些类隐藏了连接,数据检索,数据查询和数据操作的所有复杂编码。 ADO.NET是提供各种ASP.NET控件对象和后端数据源之间桥梁的技术。 在本教程中,

  • 本章将教您如何使用Struts 2以简单的步骤访问数据库。 Struts是一个MVC框架而不是数据库框架,但它为JPA/Hibernate集成提供了出色的支持。 我们将在后面的章节中讨论hibernate集成,但在本章中我们将使用普通的旧JDBC来访问数据库。 本章的第一步是设置和填充我们的数据库。 我在这个例子中使用MySQL作为我的数据库。 我在我的机器上安装了MySQL,并创建了一个名为“s

  • 本文向大家介绍C#使用晚绑定来实现压缩Access数据库的方法,包括了C#使用晚绑定来实现压缩Access数据库的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#使用晚绑定来实现压缩Access数据库的方法,通常来说VB对Com后期绑定支持得很好,在C#中可以使用反射来实现。具体方法如下: 函数实现代码如下: 那么为什么要使用晚绑定呢?可以直接在项目中添加对 JRO.JetEngi