用C#對ADO.NET資料庫完成簡單操作的方法

來源:互聯網
上載者:User

資料庫訪問是程式中應用最普遍的部分。隨著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( "\nRow(s) Added = " + nNoAdded + "\n" );
  注意: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,編譯它。
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.