明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

Asp.net在線備份、壓縮與修好Access數(shù)據(jù)庫示例代碼_asp.net圖文說明教程

[摘要]這篇文章主要介紹了Asp.net如何在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫,需要的朋友可以參考下1.問題的提出 在設(shè)計中小型Web應(yīng)用程序時,可以選擇Microsoft Accesss為數(shù)據(jù)庫。在...
這篇文章主要介紹了Asp.net如何在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫,需要的朋友可以參考下
1.問題的提出 
 
在設(shè)計中小型Web應(yīng)用程序時,可以選擇Microsoft Accesss為數(shù)據(jù)庫。在數(shù)據(jù)庫的使用過程中經(jīng)常性進行增加和刪除操作。事實上,Microsoft Access并不能有效地釋放已分配的但被刪除的對象空間,這將意味著即使你刪除了一個對象,而這個對象仍然占據(jù)著數(shù)據(jù)庫的空間,使得數(shù)據(jù)庫越來越大。不但占用不必要的空間,而且降低了數(shù)據(jù)庫的效率。特別在虛擬站點上的問題尤為突出。因此對Access數(shù)據(jù)庫進行壓縮瘦身很有實際意義。 
雖然Access數(shù)據(jù)庫自身具有“壓縮和修復(fù)數(shù)據(jù)庫”功能(工具è數(shù)據(jù)庫實用工具è壓縮和修復(fù)數(shù)據(jù)庫)。但對一般使用者來說操作不方便。通常Accesss數(shù)據(jù)庫放置在虛擬主機上,需要把它下載下來“壓縮修復(fù)”完后再傳上去很浪費時間,所以最好能在線對數(shù)據(jù)庫進行壓縮。 
 
2.在線壓縮數(shù)據(jù)庫的實現(xiàn) 
 
2.1.添加引用 
 
在VS.Net環(huán)境的解決方案下添加引用。方法如下:項目→添加引用→選項卡→瀏覽(c:/program files/comm files/System/ado/msjro.dll)。 
 
2.2.創(chuàng)建Web應(yīng)用程序窗體 
 
在Web窗體(DataBase.aspx)上放置一個按鈕: 
代碼如下:
<asp:Button ID="CompactBtn" runat="server" Text=" 壓縮數(shù)據(jù)庫 " OnClick="CompactBtn_Click" /> 
再添加一個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ù)庫壓縮失敗,請重試!"; 
 
3.備份數(shù)據(jù)庫 
 
3.1.創(chuàng)建Web應(yīng)用程序窗體 
 
在Web窗體(DataBase2.aspx)上放置一個按鈕: 
 代碼如下:
<asp:Button ID="BackUpBtn" runat="server" Text=" 備份數(shù)據(jù)庫 " OnClick="BackUpBtn_Click" /> 
再添加一個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ù)庫備份失敗,請重試!"; 
MsgLabel.CssClass = "redColor"; 
 
4.總結(jié) 
 
經(jīng)過壓縮使Microsoft Access真正釋放占據(jù)的多余空間,數(shù)據(jù)庫盡量減小,保證它最有效地運行。因此,在設(shè)計的過程中,不可忽視對Microsoft Access進行壓縮的重要性。 
建議壓縮前先對數(shù)據(jù)庫進行備份。 

Microsoft Access在很多地方得到廣泛使用,例如小型企業(yè),大公司的部門。