欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

用C#對(duì)ADO.NET數(shù)據(jù)庫完成簡單操作的方法

 更新時(shí)間:2007年03月10日 00:00:00   作者:  
數(shù)據(jù)庫訪問是程序中應(yīng)用最普遍的部分。隨著C#和ADO.NET的引入,這種操作變得更簡單。這篇文章將示范四種最基礎(chǔ)的數(shù)據(jù)庫操作。 
  ● 讀取數(shù)據(jù)。其中包括多種數(shù)據(jù)類型:整型,字符串,日期型。 
  ● 寫數(shù)據(jù)。如讀數(shù)據(jù)一樣,我們也需要寫入多種類型的數(shù)據(jù)。這可以通過SQL語句來完成。 
  ● 更新或修改數(shù)據(jù)。我們將再次用到SQL語句。 
  ● 刪除數(shù)據(jù)。用SQL實(shí)現(xiàn)。 
  上述的操作都要基于Microsoft Access 2000數(shù)據(jù)庫,但是,我們要對(duì)連接字符串進(jìn)行簡單的修改才能使用SQL或其他ADO數(shù)據(jù)。 
  開始操作 
  在使用ADO類之前,我們將把ADO.NET的命名空間和一些常用數(shù)據(jù)類包括進(jìn)來。把下面的代碼加入到你想進(jìn)行數(shù)據(jù)庫操作的地方。它的具體位置應(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ù)庫文件的路徑可能和下面不一樣: 
//Attributes 
public const string DB_CONN_STRING = 
"Driver={Microsoft Access Driver (*.mdb)}; "+ 
"DBQ=D:\\CS\\TestDbReadWrite\\SimpleTest.mdb";  
  讀取數(shù)據(jù) 
  現(xiàn)在的操作就比較有趣了。讀是通過ADODataReader類完成的(參看Chris Maunder的文章"The ADO.NET ADODataReader CLASS" 以了解更多)。讀的操作步驟如下: 
  ● 用ADO連接打開數(shù)據(jù)庫 
ADOConnection conn = new ADOConnection(DB_CONN_STRING); 
conn.Open();  
  ● 創(chuàng)建一個(gè)SQL語句來確認(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è)簡單的例子或是ADODataReade內(nèi)建的很多例子中的一個(gè)就可以說明。例如: 
int nOrdinalAge = dr.GetOrdinal( "Age" ); 
int nAge = dr.GetInt32( nOrdinalAge ); 
DateTime tUpdated = (DateTime)dr["Updated"]; 
  注意通過名字定位GetOrdinal字段的用法。如果字段是空的(沒有填入值),上面的代碼會(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語句很容易實(shí)現(xiàn)。下面的代碼通過一個(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í)際上是需要寫的。 
  插入 
  上述代碼通過一條SQL語句插入一條記錄。這條命令稍后執(zhí)行。命令格式中需要注意的是: 
  ● 數(shù)值直接賦值,不同單引號(hào)('); 
  ● 字符串必須用單引號(hào)括起來 ('blah'); 
  ● 字符串中不能包含任何單引號(hào)或是雙引號(hào); 
  ● 日期和時(shí)間都要以國際格式包括在單引號(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è)簡單的控制程序,它執(zhí)行Microsoft Access數(shù)據(jù)庫中提供的所有操作。在Visual Studio.NET IDE將TestDbReadWrite.csproj 作為工程文件打開就可以編譯它。在MainConsole.cs中改變DB_CONN_STRIN的值,讓其指向SimpleTest.mdb,編譯它。

相關(guān)文章

  • Unity3D如何獲取時(shí)間戳或北京時(shí)間

    Unity3D如何獲取時(shí)間戳或北京時(shí)間

    這篇文章主要為大家詳細(xì)介紹了Unity3D獲取時(shí)間戳或北京時(shí)間的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • 詳解C#中線程傳參,返回值和多線程沖突問題的解決

    詳解C#中線程傳參,返回值和多線程沖突問題的解決

    這篇文章主要為大家詳細(xì)介紹了C#中線程傳參,返回值和多線程沖突問題的解決方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2022-11-11
  • C?sharp?(#)?數(shù)據(jù)類型獲取方式

    C?sharp?(#)?數(shù)據(jù)類型獲取方式

    這篇文章主要介紹了C?sharp?(#)?數(shù)據(jù)類型獲取方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • winform壁紙工具為圖片添加當(dāng)前月的日歷信息

    winform壁紙工具為圖片添加當(dāng)前月的日歷信息

    使用用winform做了一個(gè)設(shè)置壁紙小工具,為圖片添加當(dāng)月的日歷并設(shè)為壁紙,可以手動(dòng)/定時(shí)設(shè)置壁紙,最主要的特點(diǎn)是在圖片上生成當(dāng)前月的日歷信息,感興趣的你可以參考下
    2013-03-03
  • c# 幾種常見的加密方法的實(shí)現(xiàn)

    c# 幾種常見的加密方法的實(shí)現(xiàn)

    這篇文章主要介紹了c# 幾種常見的加密方法的實(shí)現(xiàn),幫助大家更好的理解和使用c#,感興趣的朋友可以了解下
    2020-12-12
  • C#實(shí)現(xiàn)將漢字轉(zhuǎn)化為2位大寫的16進(jìn)制Unicode的方法

    C#實(shí)現(xiàn)將漢字轉(zhuǎn)化為2位大寫的16進(jìn)制Unicode的方法

    這篇文章主要介紹了C#實(shí)現(xiàn)將漢字轉(zhuǎn)化為2位大寫的16進(jìn)制Unicode的方法,分析了轉(zhuǎn)換的技巧并以實(shí)例形式給出了具體的轉(zhuǎn)換方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2014-12-12
  • C#利用ReportViewer生成報(bào)表

    C#利用ReportViewer生成報(bào)表

    這篇文章主要為大家詳細(xì)介紹了C#利用ReportViewer生成報(bào)表的相關(guān)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • C#使用System.Net郵件發(fā)送功能踩過的坑

    C#使用System.Net郵件發(fā)送功能踩過的坑

    這篇文章主要介紹了C#使用System.Net郵件發(fā)送功能踩過的坑,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • 一個(gè)進(jìn)程間通訊同步的C#框架引薦

    一個(gè)進(jìn)程間通訊同步的C#框架引薦

    這篇文章主要介紹了一個(gè)進(jìn)程間通訊同步的C#框架,代碼具有相當(dāng)?shù)姆€(wěn)定性和可維護(hù)性,隨著.NET的開源也會(huì)被注入更多活力,推薦!需要的朋友可以參考下
    2015-07-07
  • C#使用Oracle.ManagedDataAccess.dll組件連接Oracle數(shù)據(jù)庫

    C#使用Oracle.ManagedDataAccess.dll組件連接Oracle數(shù)據(jù)庫

    這篇文章介紹了C#使用Oracle.ManagedDataAccess.dll組件連接Oracle數(shù)據(jù)庫的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05

最新評(píng)論