庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>程序设计>C#语言>数据库编程>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

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

 作者:本站收集   日期:2005-8-8 10:00:49
字号选择〖 〗/ 双击滚屏 单击停止   
  数据库的访问是所有编程语言中最重要的部分,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结束
  }// 名字空间结束
上一篇:用C#访问Access数据库    下一篇:通过Visual C#.NET建一个DTS任务  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-8-8 10:00:49
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿