欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2023-11-22 14:22:10
数据库的访问是所有编程语言中最重要的部分,c#提供了ado.net部件用于对数据库进行访问。我们将从最简单易用的微软access数据库入手讨论在c#中对数据库的访问。 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数据库的过程,希望对大家的学习有所帮助。