您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關Asp.net中怎么實現在線備份Access數據庫,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
1.問題的提出
在設計中小型Web應用程序時,可以選擇Microsoft Accesss為數據庫。在數據庫的使用過程中經常性進行增加和刪除操作。事實上,Microsoft Access并不能有效地釋放已分配的但被刪除的對象空間,這將意味著即使你刪除了一個對象,而這個對象仍然占據著數據庫的空間,使得數據庫越來越大。不但占用不必要的空間,而且降低了數據庫的效率。特別在虛擬站點上的問題尤為突出。因此對Access數據庫進行壓縮瘦身很有實際意義。
雖然Access數據庫自身具有“壓縮和修復數據庫”功能(工具è數據庫實用工具è壓縮和修復數據庫)。但對一般使用者來說操作不方便。通常Accesss數據庫放置在虛擬主機上,需要把它下載下來“壓縮修復”完后再傳上去很浪費時間,所以最好能在線對數據庫進行壓縮。
2.在線壓縮數據庫的實現
2.1.添加引用
在VS.Net環境的解決方案下添加引用。方法如下:項目→添加引用→選項卡→瀏覽(c:/program files/comm files/System/ado/msjro.dll)。
2.2.創建Web應用程序窗體
在Web窗體(DataBase.aspx)上放置一個按鈕:
復制代碼 代碼如下:
<asp:Button ID="CompactBtn" runat="server" Text=" 壓縮數據庫 " OnClick="CompactBtn_Click" />
再添加一個Label控件:
<asp:Label ID="MsgLabel" runat="server"></asp:Label>
2.3.代碼狀態下,添加引用
復制代碼 代碼如下:
using System;
using System.IO;
using JRO;
2.4.添加代碼
復制代碼 代碼如下:
//壓縮數據庫
protected void CompactBtn_Click(object sender, EventArgs e)
{
string DbPath2, DbPath3, DbConn1, DbConn2;
DbPath2 = Server.MapPath("../App_Data/DataBase.mdb");//原數據庫路徑
DbPath3 = Server.MapPath("../App_Data/DataBase2.mdb");//壓縮后的數據庫路徑
DbConn1 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + DbPath2;
DbConn2 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + DbPath3;
try
{
JetEngine DatabaseEngin = new JetEngine();
DatabaseEngin.CompactDatabase(DbConn1, DbConn2);//壓縮
File.Copy(DbPath3, DbPath2, true);//將壓縮后的數據庫覆蓋原數據庫
File.Delete(DbPath3);//刪除壓縮后的數據庫
MsgLabel.Text = "數據庫壓縮成功!";
}
catch
{
MsgLabel.Text = "數據庫壓縮失敗,請重試!";
}
}
3.備份數據庫
3.1.創建Web應用程序窗體
在Web窗體(DataBase2.aspx)上放置一個按鈕:
復制代碼 代碼如下:
<asp:Button ID="BackUpBtn" runat="server" Text=" 備份數據庫 " OnClick="BackUpBtn_Click" />
再添加一個Label控件:
<asp:Label ID="MsgLabel" runat="server"></asp:Label>
3.2.代碼狀態下,添加引用
復制代碼 代碼如下:
using System;
using System.IO;
3.3.添加代碼
復制代碼 代碼如下:
//備份數據庫
protected void BackUpBtn_Click(object sender, EventArgs e)
{
string DbPath2, DbPath3, DbName4DbPath3;
DbName4DbPath3 = DateTime.Now.ToString().Replace(":",".");
DbPath2 = Server.MapPath("../App_Data/DataBase.mdb");
DbPath3 = Server.MapPath("../App_Data/" + DbName4DbPath3 + ".mdb");
try
{
File.Copy(DbPath2, DbPath3, true);
MsgLabel.Text = "數據庫備份成功到" + DbName4DbPath3 + ".mdb!";
}
catch
{
MsgLabel.Text = "數據庫備份失敗,請重試!";
MsgLabel.CssClass = "redColor";
}
}
看完上述內容,你們對Asp.net中怎么實現在線備份Access數據庫有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。