首页 | 互联网 | IT动态 | 网络设备 | 服务器 | IDC | 安全 | Cisco | Windows | Linux | Java | .Net | Oracle | CIW | 华为 | 专题
IT技术 | 网页设计 | 平面设计 | 电子书下载 | 教学视频 | 方案 | 数字网校 | 直播室 | 虚拟考场 | 面授培训 | 搜索 | 博客 | 沙龙 | 论坛
首页 | JAVA | C# | VB | VB.NET | C/C++ | delphi | 工程管理 | 其他语言 | 论坛
免费注册一站通帐号,参与直播、论坛、下载、博客、网摘、评论,展现我的风采!
您现在的位置: 中国IT实验室 >> 桌面开发 >> C# >> 文章正文
在C#中使用ADO.Net部件来访问Access数据库
来源:中国IT实验室整理  时间:2007-4-7

  数据库的访问是所有编程语言中最重要的部分,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 β1编译下面的程序代码。
 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结束
  }// 名字空间结束 
【责编:Lili】

中国IT教育热线咨询

相关文章
Visual C#多线程参数传递浅析
用C#创建COM对象
VB.Net连接各种数据库的几种方法
正确理解C#中的ref关键字
利用C#实现标注式消息提示窗口
Java技术在多数据库系统中的应用研究
在Delphi数据库应用程序中常见错误
C#和Visual Basic中的闭包与对象生存时…
推荐文章
· 用C#创建COM对象
· IT管理十大失误及其对策
· VC中利用MFC设计绘图程序初步
· JAVA中对象创建和初始化过程
· C语言中的位域的使用
· 浅谈Java桌面应用程序开发
· C#的前途如何?
· 几种VC++数据库开发技术的相对比较
 精彩友情推荐
·锐捷交换机报价
·锐捷交换机
·锐捷网络网络交换机
·smc交换机
·smc交换机报价
·IDC资讯大全
·机房品质万里行
·IDC托管必备知识
·全国IDC报价
·网站推广优化
最新更新 推荐文章
·Visual Basic 9.0隐式类型的局部…09-30
·JMX+J2SE5.0实现Web应用的安全管…09-30
·多线程、Socket技术及委托技术的…09-21
·Visual C#多线程参数传递浅析09-21
·浅谈Java中利用JCOM实现仿Excel编…09-21
·基于Java的界面布局DSL的设计与实…09-21
·Java开发中的事件驱动模型实例详…09-21
·并发工程原则应用到软件项目中09-06
·Delphi初学者应小心的六大陷阱09-06
·VC开发多语言界面支持的简单方法09-06
·用C#创建COM对象09-06
·用C#创建COM对象09-06
·IT管理十大失误及其对策08-30
·VC中利用MFC设计绘图程序初步08-23
·JAVA中对象创建和初始化过程08-23
·C语言中的位域的使用08-09
·浅谈Java桌面应用程序开发08-09
·C#的前途如何?08-02
·几种VC++数据库开发技术的相对比较07-12
·用Visual C#实现网络封包监视07-12
·VB.NET中的TextBox控件详解07-12
·VB.NET实现PC与掌上电脑PPC的双向通信07-05
  培训中心