最新文章專(zhuān)題視頻專(zhuān)題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專(zhuān)題1關(guān)鍵字專(zhuān)題50關(guān)鍵字專(zhuān)題500關(guān)鍵字專(zhuān)題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專(zhuān)題關(guān)鍵字專(zhuān)題tag2tag3文章專(zhuān)題文章專(zhuān)題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專(zhuān)題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

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

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:39:11
文檔

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

Asp.net在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫(kù)示例代碼:1.問(wèn)題的提出 在設(shè)計(jì)中小型Web應(yīng)用程序時(shí),可以選擇Microsoft Accesss為數(shù)據(jù)庫(kù)。在數(shù)據(jù)庫(kù)的使用過(guò)程中經(jīng)常性進(jìn)行增加和刪除操作。事實(shí)上,Microsoft Access并不能有效地釋放已分配的但被刪除的對(duì)象空間,這將意味著即使你刪除了一個(gè)對(duì)象,而這個(gè)對(duì)象仍然占據(jù)
推薦度:
導(dǎo)讀Asp.net在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫(kù)示例代碼:1.問(wèn)題的提出 在設(shè)計(jì)中小型Web應(yīng)用程序時(shí),可以選擇Microsoft Accesss為數(shù)據(jù)庫(kù)。在數(shù)據(jù)庫(kù)的使用過(guò)程中經(jīng)常性進(jìn)行增加和刪除操作。事實(shí)上,Microsoft Access并不能有效地釋放已分配的但被刪除的對(duì)象空間,這將意味著即使你刪除了一個(gè)對(duì)象,而這個(gè)對(duì)象仍然占據(jù)

1.問(wèn)題的提出

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

2.在線壓縮數(shù)據(jù)庫(kù)的實(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ù)庫(kù) " 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ù)庫(kù)
protected void CompactBtn_Click(object sender, EventArgs e)
{
string DbPath1, DbPath2, DbConn1, DbConn2;

DbPath1 = Server.MapPath("../App_Data/DataBase.mdb");//原數(shù)據(jù)庫(kù)路徑
DbPath2 = Server.MapPath("../App_Data/DataBase2.mdb");//壓縮后的數(shù)據(jù)庫(kù)路徑
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ù)庫(kù)覆蓋原數(shù)據(jù)庫(kù)
File.Delete(DbPath2);//刪除壓縮后的數(shù)據(jù)庫(kù)

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

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

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

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


<asp:Button ID="BackUpBtn" runat="server" Text=" 備份數(shù)據(jù)庫(kù) " 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ù)庫(kù)
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ù)庫(kù)備份成功到" + DbName4DbPath2 + ".mdb!";
}
catch
{
MsgLabel.Text = "數(shù)據(jù)庫(kù)備份失敗,請(qǐng)重試!";
MsgLabel.CssClass = "redColor";
}
}

4.總結(jié)

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

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

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

Asp.net在線備份、壓縮和修復(fù)Access數(shù)據(jù)庫(kù)示例代碼:1.問(wèn)題的提出 在設(shè)計(jì)中小型Web應(yīng)用程序時(shí),可以選擇Microsoft Accesss為數(shù)據(jù)庫(kù)。在數(shù)據(jù)庫(kù)的使用過(guò)程中經(jīng)常性進(jìn)行增加和刪除操作。事實(shí)上,Microsoft Access并不能有效地釋放已分配的但被刪除的對(duì)象空間,這將意味著即使你刪除了一個(gè)對(duì)象,而這個(gè)對(duì)象仍然占據(jù)
推薦度:
  • 熱門(mén)焦點(diǎn)

最新推薦

猜你喜歡

熱門(mén)推薦

專(zhuān)題
Top