欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Asp.net在线备份、压缩和修复Access数据库示例代码

程序员文章站 2024-02-23 21:27:52
1.问题的提出 在设计中小型web应用程序时,可以选择microsoft accesss为数据库。在数据库的使用过程中经常性进行增加和删除操作。事实上,microsoft...
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 dbpath1, dbpath2, dbconn1, dbconn2;

dbpath1 = server.mappath("../app_data/database.mdb");//原数据库路径
dbpath2 = server.mappath("../app_data/database2.mdb");//压缩后的数据库路径
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);//将压缩后的数据库覆盖原数据库
file.delete(dbpath2);//删除压缩后的数据库

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 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 = "数据库备份成功到" + dbname4dbpath2 + ".mdb!";
}
catch
{
msglabel.text = "数据库备份失败,请重试!";
msglabel.cssclass = "redcolor";
}
}

4.总结

经过压缩使microsoft access真正释放占据的多余空间,数据库尽量减小,保证它最有效地运行。因此,在设计的过程中,不可忽视对microsoft access进行压缩的重要性。
建议压缩前先对数据库进行备份。