欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2014年03月13日 17:29:48   作者:  
這篇文章主要介紹了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)上放置一個按鈕:
復(fù)制代碼 代碼如下:

<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)下,添加引用
復(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)上放置一個按鈕:
復(fù)制代碼 代碼如下:

<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)下,添加引用
復(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ù)庫盡量減小,保證它最有效地運行。因此,在設(shè)計的過程中,不可忽視對Microsoft Access進行壓縮的重要性。
建議壓縮前先對數(shù)據(jù)庫進行備份。

相關(guān)文章

  • c#.net全站防止SQL注入類的代碼

    c#.net全站防止SQL注入類的代碼

    c#.net全站防止SQL注入類的代碼,需要的朋友可以參考一下
    2013-03-03
  • .net 讀取非標(biāo)準(zhǔn)配置文件的小例子

    .net 讀取非標(biāo)準(zhǔn)配置文件的小例子

    這篇文章介紹了.net 讀取非標(biāo)準(zhǔn)配置文件的小例子,有需要的朋友可以參考一下
    2013-07-07
  • ASP.NET Core開發(fā)教程之Logging利用NLog寫日志文件

    ASP.NET Core開發(fā)教程之Logging利用NLog寫日志文件

    一直很喜歡 NLog 的簡潔和擴展性,所以下面這篇文章主要給大家介紹了關(guān)于ASP.NET Core開發(fā)教程之Logging利用NLog寫日志文件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-07-07
  • linq中的分組操作符

    linq中的分組操作符

    這篇文章介紹了linq中的分組操作符,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • LINQ 標(biāo)準(zhǔn)查詢操作符

    LINQ 標(biāo)準(zhǔn)查詢操作符

    本文介紹了LINQ標(biāo)準(zhǔn)查詢操作符。沒有這些操作符,LINQ就不會存在。本文為理解這些操作符的功能提供了很好的基礎(chǔ)。了解它們將會很有幫助,因為LINQ的各種Provider都是基于這些操作符來完成各自豐富的功能。
    2010-02-02
  • web.config使用方法指南

    web.config使用方法指南

    這篇文章主要介紹了web.config使用方法,具體格式,注意點等方面,有需要的小伙伴可以參考下。
    2015-05-05
  • ASP.NET 固定標(biāo)題列與欄位的具體實現(xiàn)

    ASP.NET 固定標(biāo)題列與欄位的具體實現(xiàn)

    客戶提這個要求很久了,最近才時間弄,但是看到百度中要沒有很多詳細(xì)的代碼。廢話不多說直接貼代碼。
    2013-06-06
  • ASP.NET Eval進行數(shù)據(jù)綁定的方法

    ASP.NET Eval進行數(shù)據(jù)綁定的方法

    ASP.NET Eval在數(shù)據(jù)綁定方面的應(yīng)用是眾所周知的,不過技術(shù)在發(fā)展,當(dāng)ASP.NET Eval 1.1變成ASP.NET Eval 2.0的時候,在操作的時候會有什么變化呢?
    2013-04-04
  • ASP.NET實現(xiàn)MVC中獲取當(dāng)前URL、controller及action的方法

    ASP.NET實現(xiàn)MVC中獲取當(dāng)前URL、controller及action的方法

    這篇文章主要介紹了ASP.NET實現(xiàn)MVC中獲取當(dāng)前URL、controller及action的方法,結(jié)合實例形式分析了asp.net mvc獲取當(dāng)前URL、controller及action的具體實現(xiàn)技巧,需要的朋友可以參考下
    2017-02-02
  • NetCore 3.0文件上傳和大文件上傳的限制詳解

    NetCore 3.0文件上傳和大文件上傳的限制詳解

    這篇文章主要給大家介紹了關(guān)于NetCore 3.0文件上傳和大文件上傳限制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用NetCore 3.0具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11

最新評論