自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

淺談C# Connection對(duì)象

開發(fā) 后端
這里介紹C# Connection對(duì)象,數(shù)據(jù)庫(kù)的訪問是所有編程語(yǔ)言中最重要的部分,C#提供了ADO.Net部件用于對(duì)數(shù)據(jù)庫(kù)進(jìn)行訪問。

數(shù)據(jù)庫(kù)的訪問是所有編程語(yǔ)言中最重要的部分,C#提供了ADO.Net部件用于對(duì)數(shù)據(jù)庫(kù)進(jìn)行訪問。我們將從最簡(jiǎn)單易用的微軟Access數(shù)據(jù)庫(kù)入手討論在C#中對(duì)數(shù)據(jù)庫(kù)的訪問。

C# Connection對(duì)象和Command對(duì)象與Access類似,但在這里我們還將使用其另一個(gè)與RecordSet類似的被稱作ADODataReader的對(duì)象,它負(fù)責(zé)處理與查詢有關(guān)的RecordSet對(duì)象。

首先,必須使用微軟的Access創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)。運(yùn)行Access,創(chuàng)建一個(gè)數(shù)據(jù)庫(kù),但不要?jiǎng)?chuàng)建任何表(我們將在下面的程序中創(chuàng)建表。),保存創(chuàng)建的數(shù)據(jù)庫(kù)。

打開控制面板中的ODBC圖標(biāo),點(diǎn)擊System DNS標(biāo)簽,依次選擇Add>Microsoft Access,并點(diǎn)擊Finish按鈕。在拉下來(lái)的對(duì)話框中輸入數(shù)據(jù)源的名字,比如是mymdb,然后創(chuàng)建數(shù)據(jù)源,雙擊OK按鈕。

在下面的程序中,我們將創(chuàng)建一個(gè)表,并在其中插入一些值。

程序非常地簡(jiǎn)單和直觀。在Main()函數(shù)中,C# Connection對(duì)象將數(shù)據(jù)源的名字取到構(gòu)造器中,然后使用ADOConenction的Open()方法打開該連接。

在連接建立后,程序?qū)?chuàng)建包含二個(gè)字段的表a1,其中字段name的類型為字符型,vno的類型為整型。Create table命令已經(jīng)放在ADOCommand的構(gòu)造器中,ExecuteNonQuery()方法用于執(zhí)行這一查詢,該方法不會(huì)返回任何記錄集。同樣,Insert和Delete查詢也可以放到ADOCommand的Constructor中,因此可以象在VB中那樣傳遞任何SQL查詢。

ADODataReader是新出現(xiàn)的,它是本段程序中主要的對(duì)象,負(fù)責(zé)處理ADOCommand返回的記錄集。使用xecute()方法,就可以看到從數(shù)據(jù)庫(kù)中返回的數(shù)據(jù)。ADODataReader的Read()方法則返回布爾型的值,TRUE標(biāo)志著數(shù)據(jù)在ADODataReader對(duì)象中,而且將當(dāng)前指針移動(dòng)到了ADODataReader對(duì)象的下一條記錄上。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. //創(chuàng)建表  
  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. //刪除整個(gè)表  
  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函數(shù)結(jié)束  
  86. } // Class結(jié)束  
  87. }// 名字空間結(jié)束  

以上介紹C# Connection對(duì)象

【編輯推薦】

  1. C#參數(shù)類型學(xué)習(xí)筆記
  2. 處理C#消息的方法
  3. C#重載LoadPostData方法
  4. 概述C#復(fù)合控件構(gòu)建
  5. C# JavaScript函數(shù)使用
責(zé)任編輯:佚名 來(lái)源: 博客園
相關(guān)推薦

2009-08-12 11:24:25

C# String對(duì)象

2009-08-31 09:37:09

C# Employee

2009-09-02 15:41:21

C# HTTPWebR

2009-08-18 09:06:41

C#對(duì)象和集合

2009-09-02 16:36:37

C#調(diào)用Excel對(duì)象

2009-07-31 17:51:27

C#對(duì)象初始化

2009-05-08 09:46:37

微軟C#集合對(duì)象

2009-08-26 15:28:52

C#對(duì)象集合初始化器

2009-08-03 15:06:43

C# Stack對(duì)象C# Queue對(duì)象

2009-08-20 18:30:33

C# ReaderWr

2011-09-21 10:56:31

C#結(jié)構(gòu)

2009-08-07 11:26:53

C#數(shù)組結(jié)構(gòu)

2009-08-25 16:16:43

C# oledbcon

2009-08-26 15:46:01

C#匿名類型

2009-08-06 15:30:23

C#類型系統(tǒng)

2009-08-14 17:58:05

C#接口方法

2009-08-26 13:15:38

C#選擇控制

2009-08-20 10:24:52

C#開發(fā)WinForm

2009-08-10 10:04:25

C#抽象類C#接口

2012-03-14 10:48:05

C#
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)