程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> 用C#對ADO.NET數據庫完成簡單操作(2)

用C#對ADO.NET數據庫完成簡單操作(2)

編輯:關於C語言

讀取數據

現在的操作就比較有趣了。讀是通過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 );

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved