這一節我要講的是大家非常關心的,肯定也是非常感興趣的部分.嘿嘿,也是我寫教程最拿手的部分----ADO數據庫訪問.想到這,我就想起我在去年寫的"訪問資料庫"系列文章,嘿嘿!所以呢,如果你覺得對記錄集之類的東西比較難理解的話,我推薦你先看一看我的那幾篇文章.好了,讓我們開始吧!
什麼是ADO(ActiveX Data Objects譯作ActiveX資料物件),ADO是一個非常簡單的思想,一種讓你僅用一種方式去存取資料的思想.ADO不算一個新的思想,僅是採用現有的資料存取技術,將其融合起來.如果你不理解ADO,想一想ODBC吧!其實我們在搞asp的時候,就用到了ADO,還記得嗎,那個曾經被我們用過無數次的set conn=Server.CreateObject("ADODB.Connection")嗎?是的,就是它.至於ADO的一些概念性的東西,請大家自行查閱資料,不過,其實不了解也沒有關係,只把它想像成一個M$給我們的存取資料的工具吧!
OK,下面的例子是以一個M$ access 2000的資料庫為基礎的,它的結構如下,表名是Categories,文件名是BugTypes.mdb ,趕快建一個吧:
Category ID Category Name
1 Bugbash stuff
2 Appweek Bugs
3 .NET Reports
4 Internal support
,我先把所有的程序都寫出來的
000: // ADOadosample.cs001: using System;
002: using System.Data;
003: using System.Data.ADO;
004:
005: public class MainClass
004:
005: public class MainClass
006:
005: public class MainClass
void Main ()
008: {
009: // 設定好連接字串和選擇命令字串010: string strAccessConn = "PRovider=Microsoft.Jet.OLEDB.4.0;Data Source=BugTypes.MDB";
01111111111111111111111111111111111111113 日: string strAccessSelect = "SELECT * FROM Categories";
012:
013: //建立記錄集,並將Categories這個表填進去
014: DataSet myDataSet = new DataSet();
015:mySetSet. "Categories");
016:
017: //建立ADO實例018: ADOConnection myAccessConn = new ADOConnection(strAccessConn);
019: ADODataSetCommand myAccessDataSetCmd = new ADODataSetCommand(); myAccessConn);
021:
022: myAccessConn.Open();
023: try
024: {
025: myAccessDataSetCmd.FillDataSet(myDataSet,"Categories"); 029: myAccessConn.Close();
030: }
031:
032: try
033: {
034: // 一個記錄集可以包含多個表,我們把它們放到一個數組中035: DataTable[] dta = myDataSet.Tables.All;
036: foreach (DataTable dt in dta)
037: {
038: Console.WriteLine("Found data table {0}", dt.TableName);
039: }
40:
041: //下面的兩行程式展示了兩種從一個記錄集中得到這個資料集中的表格數的方法
042: Console.WriteLine("{0} tables in data set", myDataSet.Tables.Count) ;
043: Console.WriteLine("{0} tables in data set", dta.Length);
044: //下面的幾行程式說明如何從一個記錄集中依靠表格的名稱來取得資訊
045: Console.WriteLine("{0} rows in Categories table", myDataSet.Tables["Categories"].Rows.Count);
046: //列的資訊是自動從資料庫中得到的,所以我們可以用以下的代碼047: Console.WriteLine("{0} columns in Categories table", myDataSet.Tables["Categories"].Columns.Count);
048: DataColumn[] drc = myDataSet.Tables["Categories"]. All;
049: int i = 0;
050: foreach (DataColumn dc in drc)
051: {
052: //列印出列的下標和列的名稱和資料類型053: Console.WriteLine("Column name[{0}] is {1}, of type {2}",i++ , dc.ColumnName, dc.DataType);
054: }
055: DataRow[] dra = myDataSet.Tables["Categories"]. Rows.All;
056: foreach (DataRow dr in dra)
057: {
058: //印出CategoryID和CategoryName059: Console.WriteLine("CategoryName[{0}] is {1}", dr[0] , dr[1]);
060: }
061: }
062: catch (Exception e)
063: {
064: Console.WriteLine("Oooops. Caught an exception:n{0}", e.Message );
065: }
066: }
067: }
看起來,這個例子是有一些複雜的,只怪我例子選的不好,呵呵.不過,細細分析一下,還是可以理解的.我現在說一下這個例子中幾個特別的東東.第一就是不像在ASP中,一個命令字符串被須被當作一個命令對象.020做的正是這個事情.注意,在015行有一個myDataSet .Tables.Add("Categories")語句,這並不是把資料庫中的Categories這個表填進去,只不過是建一個空表,而025才是真的填充資料.
這個範例的輸出是:
Found data table Categories
1 tables in data set
1 tables in data set
4 rows in Categories table
2 columns in Categories table
Column name[0] isegoego, of Integories table
Column name[0] isegoegoID, 532, 1 月 Cat of type System.String
CategoryName[1] is Bugbash stuff
CategoryName[2] is Appweek Bugs
CategoryName[3] is .NET Reports
CategoryName[4] is Internal port想睡覺了,什麼音樂都不管用了,呵呵.這個例子還真要花大力氣才能完全理解.O.K.886!