Asp.net在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫示例代碼(
來源:易賢網(wǎng) 閱讀:717 次 日期:2014-08-28 14:49:28
溫馨提示:易賢網(wǎng)小編為您整理了“Asp.net在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫示例代碼(”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了Asp.net如何在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫,需要的朋友可以參考下

1.問題的提出

在設(shè)計(jì)中小型Web應(yīng)用程序時(shí),可以選擇Microsoft Accesss為數(shù)據(jù)庫。在數(shù)據(jù)庫的使用過程中經(jīng)常性進(jìn)行增加和刪除操作。事實(shí)上,Microsoft Access并不能有效地釋放已分配的但被刪除的對(duì)象空間,這將意味著即使你刪除了一個(gè)對(duì)象,而這個(gè)對(duì)象仍然占據(jù)著數(shù)據(jù)庫的空間,使得數(shù)據(jù)庫越來越大。不但占用不必要的空間,而且降低了數(shù)據(jù)庫的效率。特別在虛擬站點(diǎn)上的問題尤為突出。因此對(duì)Access數(shù)據(jù)庫進(jìn)行壓縮瘦身很有實(shí)際意義。

雖然Access數(shù)據(jù)庫自身具有“壓縮和修復(fù)數(shù)據(jù)庫”功能(工具è數(shù)據(jù)庫實(shí)用工具è壓縮和修復(fù)數(shù)據(jù)庫)。但對(duì)一般使用者來說操作不方便。通常Accesss數(shù)據(jù)庫放置在虛擬主機(jī)上,需要把它下載下來“壓縮修復(fù)”完后再傳上去很浪費(fèi)時(shí)間,所以最好能在線對(duì)數(shù)據(jù)庫進(jìn)行壓縮。

2.在線壓縮數(shù)據(jù)庫的實(shí)現(xiàn)

2.1.添加引用

在VS.Net環(huán)境的解決方案下添加引用。方法如下:項(xiàng)目→添加引用→選項(xiàng)卡→瀏覽(c:/program files/comm files/System/ado/msjro.dll)。

2.2.創(chuàng)建Web應(yīng)用程序窗體

在Web窗體(DataBase.aspx)上放置一個(gè)按鈕:

代碼如下:

<asp:Button ID="CompactBtn" runat="server" Text=" 壓縮數(shù)據(jù)庫 " OnClick="CompactBtn_Click" />

再添加一個(gè)Label控件:

<asp:Label ID="MsgLabel" runat="server"></asp:Label>

2.3.代碼狀態(tài)下,添加引用

代碼如下:

using System;

using System.IO;

using JRO;

2.4.添加代碼

代碼如下:

//壓縮數(shù)據(jù)庫

protected void CompactBtn_Click(object sender, EventArgs e)

{

string DbPath1, DbPath2, DbConn1, DbConn2;

DbPath1 = Server.MapPath("../App_Data/DataBase.mdb");//原數(shù)據(jù)庫路徑

DbPath2 = Server.MapPath("../App_Data/DataBase2.mdb");//壓縮后的數(shù)據(jù)庫路徑

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

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

try

{

JetEngine DatabaseEngin = new JetEngine();

DatabaseEngin.CompactDatabase(DbConn1, DbConn2);//壓縮

File.Copy(DbPath2, DbPath1, true);//將壓縮后的數(shù)據(jù)庫覆蓋原數(shù)據(jù)庫

File.Delete(DbPath2);//刪除壓縮后的數(shù)據(jù)庫

MsgLabel.Text = "數(shù)據(jù)庫壓縮成功!";

}

catch

{

MsgLabel.Text = "數(shù)據(jù)庫壓縮失敗,請(qǐng)重試!";

}

}

3.備份數(shù)據(jù)庫

3.1.創(chuàng)建Web應(yīng)用程序窗體

在Web窗體(DataBase2.aspx)上放置一個(gè)按鈕:

代碼如下:

<asp:Button ID="BackUpBtn" runat="server" Text=" 備份數(shù)據(jù)庫 " OnClick="BackUpBtn_Click" />

再添加一個(gè)Label控件:

<asp:Label ID="MsgLabel" runat="server"></asp:Label>

3.2.代碼狀態(tài)下,添加引用

代碼如下:

using System;

using System.IO;

3.3.添加代碼

代碼如下:

//備份數(shù)據(jù)庫

protected void BackUpBtn_Click(object sender, EventArgs e)

{

string DbPath1, DbPath2, DbName4DbPath2;

DbName4DbPath2 = DateTime.Now.ToString().Replace(":",".");

DbPath1 = Server.MapPath("../App_Data/DataBase.mdb");

DbPath2 = Server.MapPath("../App_Data/" + DbName4DbPath2 + ".mdb");

try

{

File.Copy(DbPath1, DbPath2, true);

MsgLabel.Text = "數(shù)據(jù)庫備份成功到" + DbName4DbPath2 + ".mdb!";

}

catch

{

MsgLabel.Text = "數(shù)據(jù)庫備份失敗,請(qǐng)重試!";

MsgLabel.CssClass = "redColor";

}

}

4.總結(jié)

經(jīng)過壓縮使Microsoft Access真正釋放占據(jù)的多余空間,數(shù)據(jù)庫盡量減小,保證它最有效地運(yùn)行。因此,在設(shè)計(jì)的過程中,不可忽視對(duì)Microsoft Access進(jìn)行壓縮的重要性。

建議壓縮前先對(duì)數(shù)據(jù)庫進(jìn)行備份。

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

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎ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)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)