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

 更新时间:2015年09月07日 13:53:28   投稿:lijiao  
数据库的访问是所有编程语言中最重要的部分,C#提供了ADO.Net部件用于对数据库进行访问。本文从最简单易用的微软Access数据库入手讨论在C#中对数据库的访问。

数据库的访问是所有编程语言中最重要的部分,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数据库的过程,希望对大家的学习有所帮助。

相关文章

  • C#编程自学之流程控制语句

    C#编程自学之流程控制语句

    本文主要介绍流程控制语句,主要包括条件控制语句和循环控制语句的使用。读者学习本文后,应该熟练掌握C#控制语句的主要用途和使用方法,了解这些控制语句的区别。
    2015-10-10
  • C#使用ZXing.Net实现识别二维码和条码

    C#使用ZXing.Net实现识别二维码和条码

    ZXing用Java实现的多种格式的一维二维条码图像处理库,而ZXing.Net是其.Net版本的实现,本文主要为大家详细介绍了如何使用ZXing.Net实现识别二维码和条码,需要的可以参考下
    2024-01-01
  • C#使用smtp发送带附件的邮件实现方法

    C#使用smtp发送带附件的邮件实现方法

    这篇文章主要介绍了C#使用smtp发送带附件的邮件实现方法,可直接将string类型结果保存为附件,实例中备有相应的注释便于理解,需要的朋友可以参考下
    2014-11-11
  • c#获取存储过程返回值示例分享

    c#获取存储过程返回值示例分享

    这篇文章主要介绍了C#获取存储过程返回值的方法,大家参考使用吧
    2014-01-01
  • C#实现获取一年中是第几个星期的方法

    C#实现获取一年中是第几个星期的方法

    这篇文章主要介绍了C#实现获取一年中是第几个星期的方法,比较实用的功能,需要的朋友可以参考下
    2014-08-08
  • C# WPF使用AForge类库操作USB摄像头拍照并保存

    C# WPF使用AForge类库操作USB摄像头拍照并保存

    这篇文章主要为大家详细介绍了C# WPF使用AForge类库操作USB摄像头拍照并保存,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-10-10
  • C# winfrom异步加载数据不影响窗体UI的操作方法

    C# winfrom异步加载数据不影响窗体UI的操作方法

    这篇文章主要介绍了C# winfrom 异步加载数据不影响窗体UI,在 WinForms 应用程序中,如果数据加载是一个比较耗时的操作,直接在主线程中进行加载会导致 UI 冻结,这是因为 WinForms 的 UI 是单线程的,主线程被阻塞时就无法处理其他 UI 相关的任务
    2024-12-12
  • c# 二分查找算法

    c# 二分查找算法

    折半搜索,也称二分查找算法、二分搜索,是一种在有序数组中查找某一特定元素的搜索算法
    2013-10-10
  • C# 数组中的 indexOf 方法及使用

    C# 数组中的 indexOf 方法及使用

    这篇文章主要介绍了C# 数组中的 indexOf 方法以及indexof方法的使用讲解,需要的朋友可以参考下
    2018-02-02
  • C#返回多少分钟之前或多少分钟之后时间的方法

    C#返回多少分钟之前或多少分钟之后时间的方法

    这篇文章主要介绍了C#返回多少分钟之前或多少分钟之后时间的方法,涉及C#时间操作的相关技巧,需要的朋友可以参考下
    2015-05-05

最新评论