1. 程式人生 > >用C#對ADO.NET資料庫完成簡單操作

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

資料庫訪問是程式中應用最普遍的部分。隨著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,編譯它。

結論

現在你可以在C#中執行基礎資料庫操作了。找時間學學SQL,也要多讀些有關它工作原理的文章。如果你感到厭倦了,到www.mctainsh.com上去看一下更新的程式碼。

相關推薦

C#ADO.NET資料庫完成簡單操作

資料庫訪問是程式中應用最普遍的部分。隨著C#和ADO.NET的引入,這種操作變得更簡單。這篇文章將示範四種最基礎的資料庫操作。 ● 讀取資料。其中包括多種資料型別:整型,字串,日期型。 ● 寫資料。如讀資料一樣,我們也需要寫入多種型別的資料。這可以通過SQL語句來完成。

MFC中利用ADO資料庫進行簡單操作的例項

目標:實現對資料庫中的資料進行簡單地操作,包括增、刪、改、查。 第一步,建立一個基於對話方塊的應用程式,命名為TestAdo 第二步,按照圖1的介面佈局新增控制元件 圖1 程式介面示意圖 第三步,程式碼實現      首先,要用#import語句來引用支援ADO的

ADO.NET資料庫簡單操作

一、提交單條SQL語句 下面以一次資料庫插入為例 1.定義連線字串:Server=.;DataBase=StudentManageDB;Uid=sa;Pwd=admin,如果是連線非本機的資料庫,在Server之後填寫IP地址,Server伺服器地址,Dat

C#回顧 Ado.Net C#連接數據庫進行增、刪、改、查

app linq while 一行 awk col 所有 console value 一、簡介 1、ado.net是一門數據庫訪問技術。 他可以通過程序來操作數據庫 2、類庫 Connection 類 和數據庫交互,必須連接它。連接幫助指明數據庫服務器、數據庫名字、用戶名、

c語言連結MySQL資料庫出現Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock'

這個問題,困擾了我好幾天,最後終於解決了。首先,我用find命令找了半天,也只有/tmp/mysql.sock,當時我很崩潰啊,後來看到一篇文章,我忘了地址,讓我有感,於是解決了這個問題。 1、在/var/run/目錄下建立一個mysqld的資料夾(如果這個資料夾沒有的話)。 sudo

《B/S模式下ADO.NET資料庫訪問技術的設計及應用》論文筆記(十七)

一、基本資訊 標題:B/S模式下ADO.NET資料庫訪問技術的設計及應用 時間:2014 來源:電子測試 關鍵詞:B/S模式; ADO.NET資料庫訪問技術; 設計; 應用; 二、研究內容 1.ADO.NET資料庫訪問技術的兩種模式: 連線模式下的資料庫訪問技術:

看“高手”如何理解ADO.NET資料庫訪問技術

ADO.NET資料庫訪問技術是系統開發的一項必備技能,如何輕鬆理解它的精髓呢?其實就是3個步驟4個要點。 1、使用連線物件Connection連線資料來源 2、使用命令物件Command執行SQL語句操縱資料庫 3、使用資料讀取器物件DataReader讀取資料 4、使用資料集物件DataSet和

ADO.net資料庫訪問技術(一)

          現在,幾乎所有的管理軟體都會和資料庫打交道,ADO.net是新一代的資料存取技術,是一個全新的資料庫訪問模型,支援記憶體中的離線訪問!記得之前敲過的機房收費系統,基本上每個窗體都會

初識和利用Servlet,獲取和顯示頁面提交的資料以及MySQL資料庫簡單操作 7.04

Servlet:web伺服器端的程式設計技術。是繼承了javax.servlet.http.HttpServlet類的Java類。由支援servlet的web伺服器(tomcat)呼叫和啟動執行。一個

基於DevExpress的C#窗體應用程式設計—資料庫簡單增刪改查

1.開啟Microsoft Visual Studio,點選檔案,新建專案,選擇C#窗體應用程式 2.將Form1重新命名為StuManager,更改窗體StuManager的Text屬性為學生資訊 3.在工具箱選擇工具LayoutContr

C語言連結mysql資料庫

第一步,安全 mysql資料庫,包括伺服器和客服端,另外C語言還需安裝底層mysql介面: sudo apt-get install libmysqlclient-dev第二步,在Ubuntu輸入命令列判斷資料庫是否正常開啟: mysql -u root -p第三步

Python微信好友進行簡單統計分析,獲取好友的基本資訊!

早些日子有人問我我的微信裡面有一共多少朋友,我就隨後拉倒了通訊錄最下面就找到了微信一共有多少位好友。然後他又問我,這裡面你認識多少人?這一句話問的我很無語。一千多個好友我真的不知道認識的人有多少。他還緊追著不放了,你知道你微信朋友的男女比例嘛?你知道你微信朋友大部分來自什麼地方嗎? 不知道

Ado.Net資料庫連線字串

1.使用SqlConnection物件: a. Sql 驗證 public void SqlConnectionOpen() { SqlConnection conn= new SqlConnection(); conn.ConnectionString =

c語言連結MySQL資料庫出現Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock'

這個問題,困擾了我好幾天,最後終於解決了。首先,我用find命令找了半天,也只有/tmp/mysql.sock,當時我很崩潰啊,後來看到一篇文章,我忘了地址,讓我有感,於是解決了這個問題。 1、在/var/run/目錄下建立一個mysqld的資料夾(如果這個資

編寫Linux下C語言訪問MySQL資料庫的程式

  在編寫這個程式的時候我和同學費了很大的力氣特別是在編譯的時候,下面我就把自己編譯的經驗給大家分享一下,希望大家能少走一些彎路。     我自己裝了mysql-5.0.41-linux-i686-glibc23.tar.gz 安裝部分就不說了!

C api 連線mysql資料庫的 開發例項

1. 下載mysql c connector 安裝包; 有兩種方法:                  1 下載tar檔案, 將其中的的 lib, include , bin 都放在 /usr/local 相應的目錄下;                  2. 也可配置連

C#XML文件的各種操作方法

C# XML文件的各種操作方法 內容來自越康體育分享。 XML:Extensible Markup Language(可擴展標記語言)的縮寫,是用來定義其它語言的一種元語言,其前身是SGML(Standard Generalized Markup Language,標準通用標

C#文字的寫入與讀取操作

C#對文字的寫入與讀取操作。 示例:使用txt文字模仿日誌功能的寫入與讀取操作。 1、寫入操作 /// <summary> /// 寫入日誌 /// </summary> public static void WriteLog(string message)

《mysql資料庫簡單操作筆記》

《資料庫的簡單操作筆記》 <---- 一、     1.建立資料庫;     mysql> create database db_admin;      2.檢視資

C# txt文字進行按行操作簡易教程

using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.