亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

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

2020-01-24 03:50:25
字體:
來源:轉載
供稿:網友
數據庫訪問是程序中應用最普遍的部分。隨著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,編譯它。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩黄色高清视频| 日韩精品在线视频观看| 国产精品成人av性教育| 亚洲综合一区二区不卡| 国产精品老牛影院在线观看| 一道本无吗dⅴd在线播放一区| 国产精品情侣自拍| 国产精品高清网站| 亚洲大胆美女视频| 日韩在线观看免费高清| 成人看片人aa| 国产成人高潮免费观看精品| 精品国产欧美成人夜夜嗨| 欧美日韩午夜视频在线观看| 91免费视频国产| 97精品视频在线| 怡红院精品视频| 国产激情视频一区| 8x拔播拔播x8国产精品| 国产成人jvid在线播放| 中文字幕亚洲激情| 亚洲国产一区二区三区在线观看| 亚洲伊人一本大道中文字幕| 91美女高潮出水| 欧美老女人在线视频| 国产精品精品一区二区三区午夜版| 欧美性猛交xxxx乱大交极品| 日韩视频免费中文字幕| 成人做爽爽免费视频| 国产精品视频地址| 精品无人区乱码1区2区3区在线| 久久精品电影网| 欧美激情videos| 国产亚洲精品久久久久动| 九九热这里只有精品6| 亚洲影院色无极综合| 5566成人精品视频免费| 91精品国产高清自在线| 国产精品入口免费视频一| 欧美做爰性生交视频| 欧美日韩人人澡狠狠躁视频| 欧美日韩国产精品一区二区不卡中文| 日韩av网址在线观看| 91在线观看免费网站| 97国产精品视频人人做人人爱| 91亚洲精品视频| 欧美亚洲免费电影| 国产精品一区二区三区久久久| 日韩女在线观看| 国产成人精品综合久久久| 日韩欧美中文字幕在线播放| 亚洲韩国日本中文字幕| 91精品久久久久久久久久入口| 久久综合伊人77777蜜臀| 中文字幕欧美视频在线| 日韩成人在线视频网站| 日韩美女视频中文字幕| 国产日韩欧美自拍| 亚洲黄页网在线观看| 国产精品精品一区二区三区午夜版| 久久综合色影院| 亚洲国产精品女人久久久| 影音先锋日韩有码| 成人欧美一区二区三区在线| 欧美午夜精品在线| 国产一区二区三区欧美| 久久精品视频中文字幕| 国产综合久久久久久| 精品久久久久久久久久国产| 国产欧美日韩视频| 亚洲欧洲av一区二区| 中文在线不卡视频| 成人欧美一区二区三区在线湿哒哒| 久久成人综合视频| 色婷婷综合成人| 中文字幕欧美日韩| 最近2019中文免费高清视频观看www99| 日韩中文字幕视频| 日韩经典中文字幕| 狠狠躁夜夜躁久久躁别揉| 97视频在线免费观看| 亚洲精品在线看| 欧美成人中文字幕| 国产精品露脸av在线| 亚洲国产小视频| 538国产精品视频一区二区| 人人爽久久涩噜噜噜网站| 亚洲人成网站999久久久综合| 91精品啪在线观看麻豆免费| 国模精品视频一区二区三区| 一本久久综合亚洲鲁鲁| 91av在线播放视频| 欧美黑人又粗大| 日韩亚洲精品电影| 亚洲人精品午夜在线观看| 少妇高潮 亚洲精品| 97成人精品区在线播放| 国产亚洲一区二区在线| 中文字幕日韩高清| 日韩精品免费在线播放| 亚洲成年网站在线观看| 91夜夜揉人人捏人人添红杏| 亚洲欧美一区二区精品久久久| 日本精品一区二区三区在线| 成人在线精品视频| 九九热这里只有在线精品视| 不卡中文字幕av| 国产精品第七十二页| 成人午夜黄色影院| 国产精品视频专区| 狠狠做深爱婷婷久久综合一区| 欧美日韩午夜视频在线观看| 亚洲国产精品va在线看黑人动漫| 欧美乱大交做爰xxxⅹ性3| 亚洲国产成人精品一区二区| 国产精品伦子伦免费视频| 亚洲欧美成人精品| 国产极品精品在线观看| 日韩在线免费视频观看| 欧美第一黄网免费网站| 亚洲精品欧美日韩| 成人欧美一区二区三区黑人孕妇| 69**夜色精品国产69乱| 亚洲精品欧美一区二区三区| 欧美成人精品不卡视频在线观看| 超薄丝袜一区二区| 欧美综合第一页| 国产精品1区2区在线观看| 成人性生交大片免费看视频直播| 2019亚洲日韩新视频| 综合网中文字幕| 日韩风俗一区 二区| 欧美激情视频网址| 久久久成人精品| 成人h猎奇视频网站| 国产精品一区久久久| 国产欧美日韩免费| 日韩在线观看免费高清完整版| 精品亚洲aⅴ在线观看| 国产精品久久久久久久久久小说| 国产精品露脸自拍| 日韩一区二区福利| 国内外成人免费激情在线视频| 日韩av电影手机在线观看| 全色精品综合影院| 久久久国产精彩视频美女艺术照福利| 亚洲精品久久久久久久久久久久久| 亚洲а∨天堂久久精品喷水| 亚洲黄色www网站| 亚洲精品综合精品自拍| 热99精品里视频精品| 日韩国产高清污视频在线观看| 亚洲电影成人av99爱色| 国产精品久久久久久久久| 尤物九九久久国产精品的特点| 久久天天躁日日躁| 午夜精品在线视频| 亚洲free性xxxx护士hd| 久久久精品国产网站| 亚洲xxxx妇黄裸体| 狠狠操狠狠色综合网| 韩国三级日本三级少妇99| 日韩欧美在线播放| 欧美午夜精品在线|