主頁 > 知識庫 > Asp.net在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫示例代碼

Asp.net在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫示例代碼

熱門標(biāo)簽:福州人工智能電銷機(jī)器人加盟 地圖標(biāo)注多少錢一張 宿遷智能外呼系統(tǒng)排名 怎樣給陜西地圖標(biāo)注顏色 廣州銷售外呼系統(tǒng)定制 電銷機(jī)器人 數(shù)據(jù) 400電話辦理信任翰諾科技 云狐人工智能電話機(jī)器人 ai電銷機(jī)器人對貸款有幫助嗎
1.問題的提出

在設(shè)計(jì)中小型Web應(yīng)用程序時(shí),可以選擇Microsoft Accesss為數(shù)據(jù)庫。在數(shù)據(jù)庫的使用過程中經(jīng)常性進(jìn)行增加和刪除操作。事實(shí)上,Microsoft Access并不能有效地釋放已分配的但被刪除的對象空間,這將意味著即使你刪除了一個(gè)對象,而這個(gè)對象仍然占據(jù)著數(shù)據(jù)庫的空間,使得數(shù)據(jù)庫越來越大。不但占用不必要的空間,而且降低了數(shù)據(jù)庫的效率。特別在虛擬站點(diǎn)上的問題尤為突出。因此對Access數(shù)據(jù)庫進(jìn)行壓縮瘦身很有實(shí)際意義。
雖然Access數(shù)據(jù)庫自身具有“壓縮和修復(fù)數(shù)據(jù)庫”功能(工具è數(shù)據(jù)庫實(shí)用工具è壓縮和修復(fù)數(shù)據(jù)庫)。但對一般使用者來說操作不方便。通常Accesss數(shù)據(jù)庫放置在虛擬主機(jī)上,需要把它下載下來“壓縮修復(fù)”完后再傳上去很浪費(fèi)時(shí)間,所以最好能在線對數(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è)按鈕:
復(fù)制代碼 代碼如下:

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)下,添加引用
復(fù)制代碼 代碼如下:

using System;
using System.IO;
using JRO;

2.4.添加代碼
復(fù)制代碼 代碼如下:

//壓縮數(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ù)庫壓縮失敗,請重試!";
}
}

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

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

在Web窗體(DataBase2.aspx)上放置一個(gè)按鈕:
復(fù)制代碼 代碼如下:

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)下,添加引用
復(fù)制代碼 代碼如下:

using System;
using System.IO;

3.3.添加代碼
復(fù)制代碼 代碼如下:

//備份數(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ù)庫備份失敗,請重試!";
MsgLabel.CssClass = "redColor";
}
}

4.總結(jié)

經(jīng)過壓縮使Microsoft Access真正釋放占據(jù)的多余空間,數(shù)據(jù)庫盡量減小,保證它最有效地運(yùn)行。因此,在設(shè)計(jì)的過程中,不可忽視對Microsoft Access進(jìn)行壓縮的重要性。
建議壓縮前先對數(shù)據(jù)庫進(jìn)行備份。
您可能感興趣的文章:
  • C#實(shí)現(xiàn)GZip壓縮和解壓縮入門實(shí)例
  • c#調(diào)用winrar解壓縮文件代碼分享
  • asp.net中調(diào)用winrar實(shí)現(xiàn)壓縮解壓縮的代碼
  • 用ASP.Net實(shí)現(xiàn)文件的在線壓縮和解壓縮
  • asp.net輸出重寫壓縮頁面文件實(shí)例代碼
  • asp.net 圖片超過指定大小后等比例壓縮圖片的方法
  • 基于Asp.Net MVC4 Bundle捆綁壓縮技術(shù)的介紹
  • asp.net SharpZipLib的壓縮與解壓問題
  • ASP.NET頁面進(jìn)行GZIP壓縮優(yōu)化的幾款壓縮模塊的使用簡介及應(yīng)用測試!(附源碼)
  • C#使用iCSharpcode進(jìn)行文件壓縮實(shí)現(xiàn)方法
  • asp.net C#實(shí)現(xiàn)解壓縮文件的方法

標(biāo)簽:宜春 新疆 黃南 綿陽 延安 焦作 大興安嶺 曲靖

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Asp.net在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫示例代碼》,本文關(guān)鍵詞  Asp.net,在線,備份,壓縮,和,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Asp.net在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫示例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于Asp.net在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫示例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章