在C#中使用ADO.Net部件来访问Access数据库

来源:网络整理 责任编辑:栏目编辑 发表时间:2013-07-01 20:07 点击:
  数据库的访问是所有编程语言中最重要的部分,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())
  {
 &nb
    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • 用C#制作屏幕捕获程序
    • .NET程序员项目开发必知必会—Dev环境中的集成测试用例执行时上
    • 遍历ArrayList易犯错误
    • C#对XML操作:一个处理XML文件的类(1)
    • .NET简谈反射(动态调用)
    • 使用C#编写LED样式时钟控件
    • DataList嵌套问题 如何删除内层子DataList的记录
    • 怎样用C#实现完整文档打印功能
    • .NET简谈自定义事务资源管理器
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1