社区编辑申请
注册/登录
浅谈C# Connection对象
开发 后端
这里介绍C# Connection对象,数据库的访问是所有编程语言中最重要的部分,C#提供了ADO.Net部件用于对数据库进行访问。

数据库的访问是所有编程语言中最重要的部分,C#提供了ADO.Net部件用于对数据库进行访问。我们将从最简单易用的微软Access数据库入手讨论在C#中对数据库的访问。

C# Connection对象和Command对象与Access类似,但在这里我们还将使用其另一个与RecordSet类似的被称作ADODataReader的对象,它负责处理与查询有关的RecordSet对象。

首先,必须使用微软的Access创建一个数据库。运行Access,创建一个数据库,但不要创建任何表(我们将在下面的程序中创建表。),保存创建的数据库。

打开控制面板中的ODBC图标,点击System DNS标签,依次选择Add>Microsoft Access,并点击Finish按钮。在拉下来的对话框中输入数据源的名字,比如是mymdb,然后创建数据源,双击OK按钮。

在下面的程序中,我们将创建一个表,并在其中插入一些值。

程序非常地简单和直观。在Main()函数中,C# Connection对象将数据源的名字取到构造器中,然后使用ADOConenction的Open()方法打开该连接。

在连接建立后,程序将创建包含二个字段的表a1,其中字段name的类型为字符型,vno的类型为整型。Create table命令已经放在ADOCommand的构造器中,ExecuteNonQuery()方法用于执行这一查询,该方法不会返回任何记录集。同样,Insert和Delete查询也可以放到ADOCommand的Constructor中,因此可以象在VB中那样传递任何SQL查询。

ADODataReader是新出现的,它是本段程序中主要的对象,负责处理ADOCommand返回的记录集。使用xecute()方法,就可以看到从数据库中返回的数据。ADODataReader的Read()方法则返回布尔型的值,TRUE标志着数据在ADODataReader对象中,而且将当前指针移动到了ADODataReader对象的下一条记录上。namespace database1  

  1. {  
  2. using System;  
  3. using System.Data.ADO;  
  4.    
  5. public class Class1  
  6. {  
  7. public Class1()  
  8. {  
  9. //  
  10. // 在这里添加Constructor的逻辑  
  11. //  
  12. }  
  13.    
  14. public static int Main(string[] args)  
  15. {  
  16. try  
  17. {  
  18. ADOConnection s = new ADOConnection("Data Source=mymdb");  
  19. s.Open();  
  20. Console.WriteLine("Connection Established");  
  21.    
  22. //创建表  
  23. Console.Write("Want to Create a Table?(y/n) ");  
  24. string ch = Console.ReadLine();  
  25. if (ch == "y")  
  26. {  
  27. ADOCommand CreateTable = new ADOCommand("Create Table a1(vno integer,name char(20))", s);  
  28. CreateTable.ExecuteNonQuery();  
  29. Console.WriteLine("AOCommand Executed / Table Created");  
  30. }  
  31.    
  32.    
  33. //在表中插入值  
  34. Console.Write("Want to Insert Some values in a Table?(y/n) ");  
  35. ch = Console.ReadLine();  
  36. if (ch == "y")  
  37. {  
  38. ADOCommand InsTable = new 
  39. ADOCommand("insert into a1 values(1, ‘hi‘)", s);  
  40.    
  41. InsTable.ExecuteNonQuery();  
  42. Console.WriteLine("Values Inserted");  
  43. }  
  44.    
  45. //删除整个表  
  46. Console.Write("Want to Delete All Records Present in the Table?(y/n) ");  
  47. ch = Console.ReadLine();  
  48. if (ch == "y")  
  49. {  
  50. ADOCommand DeleteTable = new ADOCommand("Delete from a1", s);  
  51. DeleteTable.ExecuteNonQuery();  
  52. Console.WriteLine("All Records Deleted From the Table");  
  53. }  
  54.    
  55. //看所有记录  
  56. Console.Write("Want to See all the Records Present in the Table /Database (y/n)? ");  
  57. ch = Console.ReadLine();  
  58. if (ch == "y")  
  59. {  
  60. ADOCommand AllRecs = new ADOCommand("select * from a1", s);  
  61. ADODataReader r;  
  62. AllRecs.Execute(out r);  
  63. while(r.Read())  
  64. {  
  65. for(int i=0; i < r.FieldCount;i++)  
  66. {  
  67. Console.Write(r.GetValue(i)+ " ");  
  68. }  
  69. Console.WriteLine();  
  70. }  
  71. Console.WriteLine("All Records Displayed");  
  72. r.Close();  
  73. }  
  74.    
  75. s.Close();  
  76. Console.ReadLine();  
  77. }  
  78. catch(System.Exception e)  
  79. {  
  80. Console.WriteLine(e.ToString());  
  81. Console.ReadLine();  
  82. }  
  83.    
  84. return 0;  
  85. } // Main函数结束  
  86. } // Class结束  
  87. }// 名字空间结束  

以上介绍C# Connection对象

【编辑推荐】

  1. C#参数类型学习笔记
  2. 处理C#消息的方法
  3. C#重载LoadPostData方法
  4. 概述C#复合控件构建
  5. C# JavaScript函数使用
责任编辑:佚名 来源: 博客园
相关推荐

2009-08-12 11:24:25

C# String对象

2009-08-18 09:06:41

C#对象和集合

2009-08-10 10:04:25

C#抽象类C#接口

2009-08-14 17:58:05

C#接口方法

2009-02-05 15:32:23

2009-08-21 15:54:40

服务端与客户端

2009-11-04 10:35:42

ADO.NET Con

2009-11-04 10:23:05

ADO.NET Con

2009-09-04 17:23:21

C#数据库连接对象

2009-08-25 17:59:49

C#入门

2009-08-25 15:35:20

C#连接Oracle数

2009-08-20 18:47:19

C#异步通信

2009-08-17 17:42:57

C#数据库操作类

2009-08-27 17:14:36

2009-08-21 15:36:41

服务端与客户端

2009-09-04 17:49:34

C#连接数据库

2009-08-06 17:42:32

2009-08-25 16:01:32

C#.NET连接数据库

2009-08-28 15:16:32

C#实现对数据库访问

2009-08-10 14:03:08

同话题下的热门内容

太强了!Python 开发桌面小工具,让代码替我们干重复的工作!Python轻量级Web框架:Bottle库!Python居然被用来开发游戏了?盘点你想不到的Python开发场景用了那么久的Lombok,你知道它的原理么?实战 | 如何用 Python 自动化监控文件夹完成服务部署!Fury:一个基于JIT动态编译的高性能多语言原生序列化框架细思恐极,插上U盘就开始执行Python代码为什么 Python、Ruby 等语言弃用了自增运算符?

编辑推荐

使用Kotlin做开发一个月后的感想面试官问你什么是消息队列?把这篇甩给他!五大自动化测试的Python框架图文详解两种算法:深度优先遍历(DFS)和广度优先遍历(BFS)2018年最流行的十大编程语言,其中包括你用的语言吗?
我收藏的内容
点赞
收藏

51CTO技术栈公众号