小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

用C#對(duì)ADO.NET數(shù)據(jù)庫(kù)完成簡(jiǎn)單操作

 ShangShujie 2007-08-22
用C#對(duì)ADO.NET數(shù)據(jù)庫(kù)完成簡(jiǎn)單操作
數(shù)據(jù)庫(kù)訪問(wèn)是程序中應(yīng)用最普遍的部分。隨著C#和ADO.NET的引入,這種操作變得更簡(jiǎn)單。這篇文章將示范四種最基礎(chǔ)的數(shù)據(jù)庫(kù)操作。

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

  ● 寫(xiě)數(shù)據(jù)。如讀數(shù)據(jù)一樣,我們也需要寫(xiě)入多種類型的數(shù)據(jù)。這可以通過(guò)SQL語(yǔ)句來(lái)完成。

  ● 更新或修改數(shù)據(jù)。我們將再次用到SQL語(yǔ)句。

  ● 刪除數(shù)據(jù)。用SQL實(shí)現(xiàn)。

  上述的操作都要基于Microsoft Access 2000數(shù)據(jù)庫(kù),但是,我們要對(duì)連接字符串進(jìn)行簡(jiǎn)單的修改才能使用SQL或其他ADO數(shù)據(jù)。

  開(kāi)始操作

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

 

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

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

  ● 右鍵點(diǎn)擊Solution explorer--參數(shù)選項(xiàng);

  ● 選擇添加參數(shù);

  ● 選擇.NET框架欄;

  ● 雙擊System.data.dll條目;

  ● 選擇OK;

  ● System.data應(yīng)該出現(xiàn)在Solution explorer的參數(shù)列表中了。

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

  注意:程序中數(shù)據(jù)庫(kù)文件的路徑可能和下面不一樣:

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

  讀取數(shù)據(jù)

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

  ● 用ADO連接打開(kāi)數(shù)據(jù)庫(kù)

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

  ● 創(chuàng)建一個(gè)SQL語(yǔ)句來(lái)確認(rèn)要獲取的數(shù)據(jù)。這條命令執(zhí)行后返回一個(gè)ADODataReader對(duì)象。注意Execute方法中的OUT關(guān)鍵字。這是C#中傳遞參數(shù)的方式。

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

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


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

  ● 清除

  但是,作為優(yōu)秀的程序員我們應(yīng)該將代碼放在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();
}

  讀取不同的數(shù)據(jù)類型

  ["stuff"]通??梢苑祷啬硞€(gè)類型的字符串。但是要獲取一個(gè)整型或 DateTime對(duì)象,就需要列出這些數(shù)據(jù)。以一個(gè)簡(jiǎn)單的例子或是ADODataReade內(nèi)建的很多例子中的一個(gè)就可以說(shuō)明。例如:

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

  注意通過(guò)名字定位GetOrdinal字段的用法。如果字段是空的(沒(méi)有填入值),上面的代碼會(huì)引發(fā)一個(gè)異常。這種情況下我們用IsNull方法檢驗(yàn)數(shù)據(jù)是否存在。

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語(yǔ)句很容易實(shí)現(xiàn)。下面的代碼通過(guò)一個(gè)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并未出現(xiàn)在上述例子中,實(shí)際上是需要寫(xiě)的。

  插入

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

  ● 數(shù)值直接賦值,不同單引號(hào)(‘);

  ● 字符串必須用單引號(hào)括起來(lái) (‘blah‘);

  ● 字符串中不能包含任何單引號(hào)或是雙引號(hào);

  ● 日期和時(shí)間都要以國(guó)際格式包括在單引號(hào)中。(‘YYYYY/MM/DD HH:MM:SS‘)

  修改

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

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

  刪除

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

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

  關(guān)于樣例程序

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

  結(jié)論

  現(xiàn)在你可以在C#中執(zhí)行基礎(chǔ)數(shù)據(jù)庫(kù)操作了。找時(shí)間學(xué)學(xué)SQL,也要多讀些有關(guān)它工作原理的文章。如果你感到厭倦了,到www.mctainsh.com上去看一下更新的代碼。

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多