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

作者:lijiao 时间:2024-01-27 01:45:42 

数据库的访问是所有编程语言中最重要的部分,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
0
投稿

猜你喜欢

  • python无限生成不重复(字母,数字,字符)组合的方法

    2021-02-15 14:08:49
  • Python-for循环的内部机制

    2023-02-02 20:47:18
  • python Cartopy的基础使用详解

    2022-03-22 06:41:18
  • sqlserver 数据库连接字符串中的可选项收集

    2024-01-16 17:47:31
  • 给展示性图片增加提示工具条(黑白效果)

    2007-10-20 14:21:00
  • asp如何刪除客户端的Cookies?

    2010-05-18 18:25:00
  • Scrapy基于scrapy_redis实现分布式爬虫部署的示例

    2023-06-24 18:12:20
  • python使用webdriver爬取微信公众号

    2022-10-06 02:13:30
  • python提示No module named images的解决方法

    2022-01-30 21:05:11
  • Python简单实现子网掩码转换的方法

    2021-10-10 21:40:30
  • 如何查询占CPU高的oracle进程

    2024-01-27 13:16:54
  • Go语言实现一个简单的并发聊天室的项目实战

    2024-02-15 03:40:33
  • javascript一个无懈可击的实例化XMLHttpRequest的方法

    2024-04-16 09:49:19
  • Python编程之列表操作实例详解【创建、使用、更新、删除】

    2021-12-24 19:03:03
  • python数据分析必会的Pandas技巧汇总

    2023-09-14 03:44:27
  • MySQL跨服务器数据映射的实现

    2024-01-23 15:08:19
  • JavaScript文档生成工具

    2007-10-26 11:59:00
  • 远程部署工具Fabric详解(支持Python3)

    2023-10-26 14:05:18
  • scala中停止循环的三种方式(推荐)

    2023-03-20 07:03:34
  • Django渲染Markdown文章目录的方法示例

    2021-03-31 05:12:07
  • asp之家 网络编程 m.aspxhome.com