Asp.net在线备份、压缩和修复Access数据库示例代码
网络编程 2021-07-04 22:41www.168986.cn编程入门
这篇文章主要介绍了Asp.如何在线备份、压缩和修复Aess数据库,需要的朋友可以参考下
1.问题的提出
在设计中小型Web应用程序时,可以选择Microsoft Aesss为数据库。在数据库的使用过程中经常性进行增加和删除操作。事实上,Microsoft Aess并不能有效地释放已分配的但被删除的对象空间,这将意味着即使你删除了一个对象,而这个对象仍然占据着数据库的空间,使得数据库越来越大。不但占用不必要的空间,而且降低了数据库的效率。特别在虚拟站点上的问题尤为突出。对Aess数据库进行压缩瘦身很有实际意义。
虽然Aess数据库自身具有“压缩和修复数据库”功能(工具è数据库实用工具è压缩和修复数据库)。但对一般使用者来说操作不方便。通常Aesss数据库放置在虚拟主机上,需要把它下载下来“压缩修复”完后再传上去很浪费时间,所以最好能在线对数据库进行压缩。
2.在线压缩数据库的实现
2.1.添加引用
在VS.Net环境的解决方案下添加引用。方法如下项目→添加引用→选项卡→浏览(c:/program files/m 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 Aess真正释放占据的多余空间,数据库尽量减小,保证它最有效地运行。,在设计的过程中,不可忽视对Microsoft Aess进行压缩的重要性。
建议压缩前先对数据库进行备份。
在设计中小型Web应用程序时,可以选择Microsoft Aesss为数据库。在数据库的使用过程中经常性进行增加和删除操作。事实上,Microsoft Aess并不能有效地释放已分配的但被删除的对象空间,这将意味着即使你删除了一个对象,而这个对象仍然占据着数据库的空间,使得数据库越来越大。不但占用不必要的空间,而且降低了数据库的效率。特别在虚拟站点上的问题尤为突出。对Aess数据库进行压缩瘦身很有实际意义。
虽然Aess数据库自身具有“压缩和修复数据库”功能(工具è数据库实用工具è压缩和修复数据库)。但对一般使用者来说操作不方便。通常Aesss数据库放置在虚拟主机上,需要把它下载下来“压缩修复”完后再传上去很浪费时间,所以最好能在线对数据库进行压缩。
2.在线压缩数据库的实现
2.1.添加引用
在VS.Net环境的解决方案下添加引用。方法如下项目→添加引用→选项卡→浏览(c:/program files/m 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 Aess真正释放占据的多余空间,数据库尽量减小,保证它最有效地运行。,在设计的过程中,不可忽视对Microsoft Aess进行压缩的重要性。
建议压缩前先对数据库进行备份。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程