如何使用c#操作ACCESS數(shù)據(jù)庫(kù)
來(lái)源:易賢網(wǎng) 閱讀:849 次 日期:2014-10-16 09:24:13
溫馨提示:易賢網(wǎng)小編為您整理了“如何使用c#操作ACCESS數(shù)據(jù)庫(kù)”,方便廣大網(wǎng)友查閱!

如何使用c#操作ACCESS數(shù)據(jù)庫(kù):

手頭沒(méi)有Microsoft Access,如何建立數(shù)據(jù)庫(kù),一切依然簡(jiǎn)單.

首先引用C:Program FilesCommon FilesSystemadomsadox.dll,該DLL包含ADOX命名空間;

接著引用C:Program FilesCommon FilesSystemadomsjro.dll,該DLL包含JRO命名空間

SxS好問(wèn)提示:如,導(dǎo)入dll不成功,手動(dòng)把com組件導(dǎo)入為 .net組件,在用vs.net工具導(dǎo)入

using System;

using System.IO;

using ADOX; //該命名空間包含創(chuàng)建ACCESS的類(lèi)(方法)--解決方案 ==> 引用 ==> 添加引用 ==> 游覽找到.dll

using JRO; //該命名空間包含壓縮ACCESS的類(lèi)(方法)

public class Access

...{

/**////根據(jù)指定的文件名稱(chēng)創(chuàng)建ACCESS數(shù)據(jù)庫(kù)

///mdbPath:要?jiǎng)?chuàng)件的ACCESS絕對(duì)路徑

public void Create( string mdbPath )

...{

if( File.Exists(mdbPath) ) //檢查數(shù)據(jù)庫(kù)是否已存在

...{

throw new Exception("目標(biāo)數(shù)據(jù)庫(kù)已存在,無(wú)法創(chuàng)建");

}

// 可以加上密碼,這樣創(chuàng)建后的數(shù)據(jù)庫(kù)必須輸入密碼后才能打開(kāi)

mdbPath = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + mdbPath;

// 創(chuàng)建一個(gè)CatalogClass對(duì)象的實(shí)例,

ADOX.CatalogClass cat = new ADOX.CatalogClass();

// 使用CatalogClass對(duì)象的Create方法創(chuàng)建ACCESS數(shù)據(jù)庫(kù)

cat.Create(mdbPath);

}

/**////壓縮修復(fù)ACCESS數(shù)據(jù)庫(kù),mdbPath為數(shù)據(jù)庫(kù)絕對(duì)路徑

public void Compact( string mdbPath )

...{

if( !File.Exists(mdbPath) ) //檢查數(shù)據(jù)庫(kù)是否已存在

...{

throw new Exception("目標(biāo)數(shù)據(jù)庫(kù)不存在,無(wú)法壓縮");

}

//聲明臨時(shí)數(shù)據(jù)庫(kù)的名稱(chēng)

string temp = DateTime.Now.Year.ToString();

temp += DateTime.Now.Month.ToString();

temp += DateTime.Now.Day.ToString();

temp += DateTime.Now.Hour.ToString();

temp += DateTime.Now.Minute.ToString();

temp += DateTime.Now.Second.ToString() + ".bak";

temp = mdbPath.Substring(0, mdbPath.LastIndexOf("")+1) + temp;

//定義臨時(shí)數(shù)據(jù)庫(kù)的連接字符串

temp2 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + temp;

//定義目標(biāo)數(shù)據(jù)庫(kù)的連接字符串

mdbPath2 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + mdbPath;

//創(chuàng)建一個(gè)JetEngineClass對(duì)象的實(shí)例

JRO.JetEngineClass jt = new JRO.JetEngineClass();

//使用JetEngineClass對(duì)象的CompactDatabase方法壓縮修復(fù)數(shù)據(jù)庫(kù)

jt.CompactDatabase( mdbPath2, temp2 );

//拷貝臨時(shí)數(shù)據(jù)庫(kù)到目標(biāo)數(shù)據(jù)庫(kù)(覆蓋)

File.Copy( temp, mdbPath, true );

//最后刪除臨時(shí)數(shù)據(jù)庫(kù)

File.Delete( temp );

} /**//// 備份數(shù)據(jù)庫(kù),mdb1,源數(shù)據(jù)庫(kù)絕對(duì)路徑; mdb2: 目標(biāo)數(shù)據(jù)庫(kù)絕對(duì)路徑

public void Backup( string mdb1, string mdb2 )

...{

if( !File.Exists(mdb1) )

...{

throw new Exception("源數(shù)據(jù)庫(kù)不存在");

}

try

...{

File.Copy( mdb1, mdb2, true );

}

catch( IOException ixp )

...{

throw new Exception(ixp.ToString());

}

}

/**////恢復(fù)數(shù)據(jù)庫(kù),mdb1為備份數(shù)據(jù)庫(kù)絕對(duì)路徑,mdb2為當(dāng)前數(shù)據(jù)庫(kù)絕對(duì)路徑

public void Recover( string mdb1, string mdb2 )

...{

if( !File.Exists(mdb1) )

...{

throw new Exception("備份數(shù)據(jù)庫(kù)不存在");

}

try

...{

File.Copy( mdb1, mdb2, true );

}

catch( IOException ixp )

...{

throw new Exception(ixp.ToString());

}

}

}

******************************************************************************************************

在BETA2中,。NET提供了以下的NAMESPACE:

System.Data Namespace

System.Data.OleDb (和BETA1中已經(jīng)不同了,所以如果拿BETA1中的程序到BETA2中來(lái)運(yùn)行肯定不可以的)

如果想講清楚這些東西,我不認(rèn)為是我可以作到的,所以我想通過(guò)一些具體的程序來(lái)把我們對(duì)數(shù)據(jù)庫(kù)的最基本的操作(SELECT、UPDATE、DELETE、INSERT等)演示一下,其他的還是需要朋友們?cè)趯W(xué)習(xí)過(guò)程中來(lái)慢慢體會(huì)了!

要想操作一個(gè)數(shù)據(jù)庫(kù),不論是那種操作,首先要做的肯定是打開(kāi)數(shù)據(jù)庫(kù),下面我們以ACCESS數(shù)據(jù)庫(kù)來(lái)做例子說(shuō)明如何打開(kāi)一個(gè)數(shù)據(jù)庫(kù)連接!在這里我們需要用到的是:System.Data.OleDb.OleDbConnection類(lèi)!(如果操作SQL數(shù)據(jù)庫(kù),我們最好使用 System.Data.SqlClient.SqlConnection類(lèi))

我先寫(xiě)出我自己使用的程序:

using System.Data

using System.Data.OleDb

public OleDbConnection getConn()

{

string connstr="Provider=Microsoft.Jet.OLEDB.4.0 ;Data Source=F:webnotesbookclassleavenotes.mdb";

OleDbConnection tempconn= new OleDbConnection(connstr);

return(tempconn);

}

相信只要使用過(guò)ADO的朋友應(yīng)該都可以看懂的!我們先定義一個(gè)String類(lèi)型的變量,其中存放了我們連接數(shù)據(jù)庫(kù)的連接字符串,然后在定義一個(gè) System.Data.OleDb.OleDbConnection類(lèi)型的對(duì)象并實(shí)例化,最后返回這個(gè)對(duì)象!需要說(shuō)明一下的是,我并沒(méi)有把語(yǔ)句: tempconn.Open();放到這個(gè)函數(shù)中,原因我我稍后在說(shuō)明,這里只是先提醒一下!

通過(guò)上面的函數(shù),我們就已經(jīng)得到了類(lèi)似于ADO中的連接對(duì)象Connection了!下面的就是具體操作數(shù)據(jù)庫(kù)了!

在具體講操作前,我認(rèn)為有必要先認(rèn)識(shí)一下下面的兩個(gè)類(lèi):

System.Data.OleDb.OleDbDataAdapter

System.Data.OleDb.OleDbDataReader

System.Data.OleDb.OleDbDataAdapter:可以直接和DataSet聯(lián)系,并操作數(shù)據(jù)源的,它的功能相對(duì)強(qiáng)大一些,因此也比較耗系統(tǒng)資源!

System.Data.OleDb.OleDbDataReader:則有些類(lèi)似于ADO中的哪個(gè)只讀向前的記錄集,它最常用在只需要依次讀取并顯示數(shù)據(jù)的時(shí)候,相比 System.Data.OleDb.OleDbDataAdapter來(lái)說(shuō),他耗用的系統(tǒng)資源要小!其實(shí),OleDbDataReader能實(shí)現(xiàn)的功能,OleDbDataAdapter都可以實(shí)現(xiàn),不過(guò)從資源使用率的角度考慮我們應(yīng)該盡量使用前者!但有些功能,卻是必須使用 OleDbDataAdapter才可以實(shí)現(xiàn)的!

更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄

更多信息請(qǐng)查看數(shù)據(jù)庫(kù)
易賢網(wǎng)手機(jī)網(wǎng)站地址:如何使用c#操作ACCESS數(shù)據(jù)庫(kù)
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢(xún)回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢(xún)?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類(lèi)型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢(xún) | 簡(jiǎn)要咨詢(xún)須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專(zhuān)用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢(xún)關(guān)注公眾號(hào):hfpxwx
咨詢(xún)QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)