top
Loading...
用C#對ADO.NET數據庫完成簡單操作

數據庫訪問是程序中應用最普遍的部分。隨著C#和ADO.NET的引入,這種操作變得更簡單。這篇文章將示范四種最基礎的數據庫操作。

● 讀取數據。其中包括多種數據類型:整型,字符串,日期型。

● 寫數據。如讀數據一樣,我們也需要寫入多種類型的數據。這可以通過SQL語句來完成。

● 更新或修改數據。我們將再次用到SQL語句。

● 刪除數據。用SQL實現。

上述的操作都要基于Microsoft Access 2000數據庫,但是,我們要對連接字符串進行簡單的修改才能使用SQL或其他ADO數據。

開始操作

在使用ADO類之前,我們將把ADO.NET的命名空間和一些常用數據類包括進來。把下面的代碼加入到你想進行數據庫操作的地方。它的具體位置應該是命名空間行之后,類聲明之前。

using System.Data;                      // State variables    using System.Data.ADO;                  // Database    using System.Globalization;             // Date

你或許還要向System.Data命名空間添加參數,這取決于工程的類型需要。你所添加的代碼的編譯信息會提醒你這一點。添加System.Data命名空間的操作:

● 右鍵點擊Solution explorer--參數選項;

● 選擇添加參數;

● 選擇.NET框架欄;

● 雙擊System.data.dll條目;

● 選擇OK;

● System.data應該出現在Solution explorer的參數列表中了。

由于在多數操作中都會使用連接字符串,所以我建議你將它包含在使用的類中。

注意:程序中數據庫文件的路徑可能和下面不一樣:

//Attributes    public const string DB_CONN_STRING =         "Driver={Microsoft Access Driver (*.mdb)}; "+        "DBQ=D:\CS\TestDbReadWrite\SimpleTest.mdb";

讀取數據

現在的操作就比較有趣了。讀是通過ADODataReader類完成的(參看Chris Maunder的文章"The ADO.NET ADODataReader CLASS" 以了解更多)。讀的操作步驟如下:

● 用ADO連接打開數據庫

ADOConnection conn = new ADOConnection(DB_CONN_STRING);conn.Open();

● 創建一個SQL語句來確認要獲取的數據。這條命令執行后返回一個ADODataReader對象。注意Execute方法中的OUT關鍵字。這是C#中傳遞參數的方式。

ADODataReader dr;ADOCommand cmd = new ADOCommand( "SELECT * FROM Person", conn );cmd.Execute( out dr);

● 循環遍歷ADODataReader中的每條記錄,直到完成。注意:數據被作為字符串直接返回。字段名顯示了要讀取的字段。

while( dr.Read() ){System.Console.WriteLine( dr["FirstName"] );}

● 清除

但是,作為優秀的程序員我們應該將代碼放在try/catch/finally 中,確保我們能夠控制所有意外。

try    {        .... the database operations ...    }    catch( Exception ex )    {        System.Console.WriteLine( "READING:" );        System.Console.WriteLine( "  ERROR:" + ex.Message );        System.Console.WriteLine( "  SQL  :" + sSqlCmd );        System.Console.WriteLine( "  Conn.:" + DB_CONN_STRING );    }    finally    {        // Close the connection        if( conn.State == DBObjectState.Open )            conn.Close();}

讀取不同的數據類型

["stuff"]通常可以返回某個類型的字符串。但是要獲取一個整型或 DateTime對象,就需要列出這些數據。以一個簡單的例子或是ADODataReade內建的很多例子中的一個就可以說明。例如:

int nOrdinalAge = dr.GetOrdinal( "Age" );    int nAge = dr.GetInt32( nOrdinalAge );    DateTime tUpdated = (DateTime)dr["Updated"];

注意通過名字定位GetOrdinal字段的用法。如果字段是空的(沒有填入值),上面的代碼會引發一個異常。這種情況下我們用IsNull方法檢驗數據是否存在。

int nOrdinalAge = dr.GetOrdinal( "Age" );    if( dr.IsNull( nOrdinalAge ) )    {        System.Console.WriteLine( " Age  : Not given!" );    }    else    {        int nAge = dr.GetInt32( nOrdinalAge );        System.Console.WriteLine( " Age  : " + nAge );

插入,修改,刪除和其他SQL命令

插入,修改,和刪除用SQL語句很容易實現。下面的代碼通過一個SQL命令插入一條記錄:

// SQL command    String sSQLCommand = "INSERT INTO Person (Age, FirstName,     Description, Updated)  " +                         "VALUES( 55, 'Bob', 'Is a Penguin', '2001/12/25 20:30:15' );";    // Create the command object    ADOCommand cmdAdder = new ADOCommand(        sSQLCommand,        DB_CONN_STRING);    cmdAdder.ActiveConnection.Open();    // Execute the SQL command    int nNoAdded = cmdAdder.ExecuteNonQuery();    System.Console.WriteLine( "Row(s) Added =     " + nNoAdded + "" );

注意:try/catch并未出現在上述例子中,實際上是需要寫的。

插入

上述代碼通過一條SQL語句插入一條記錄。這條命令稍后執行。命令格式中需要注意的是:

● 數值直接賦值,不同單引號(');

● 字符串必須用單引號括起來 ('blah');

● 字符串中不能包含任何單引號或是雙引號;

● 日期和時間都要以國際格式包括在單引號中。('YYYYY/MM/DD HH:MM:SS')

修改

UPDATE命令指示了要被修和已做修改的記錄。ExecuteNonQuery()返回的值顯示變化的紀錄的數目,這樣如果在表格中有5個Peter那它就會返回5。

String sSQLCommand = "UPDATE Person SET Age = 27 WHERE FirstName = 'Peter'";

刪除

DELETE命令顯示要被刪除的紀錄。這可能會是幾條。ExecuteNonQuery()返回的值顯示變化的紀錄的數目,這樣如果表中有2個Bobo就返回2。這兩個Bobo都會被刪除。

String sSQLCommand = "DELETE FROM Person WHERE FirstName = 'Bobo'";

關于樣例程序

樣例是個簡單的控制程序,它執行Microsoft Access數據庫中提供的所有操作。在Visual Studio.NET IDE將TestDbReadWrite.csproj 作為工程文件打開就可以編譯它。在MainConsole.cs中改變DB_CONN_STRIN的值,讓其指向SimpleTest.mdb,編譯它。

結論

現在你可以在C#中執行基礎數據庫操作了。找時間學學SQL,也要多讀些有關它工作原理的文章。如果你感到厭倦了,到www.mctainsh.com上去看一下更新的代碼。

作者:http://www.zhujiangroad.com
來源:http://www.zhujiangroad.com
北斗有巢氏 有巢氏北斗