• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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 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进行压缩的重要性。
    建议压缩前先对数据库进行备份。
    您可能感兴趣的文章:
    • C#实现GZip压缩和解压缩入门实例
    • c#调用winrar解压缩文件代码分享
    • asp.net中调用winrar实现压缩解压缩的代码
    • 用ASP.Net实现文件的在线压缩和解压缩
    • asp.net输出重写压缩页面文件实例代码
    • asp.net 图片超过指定大小后等比例压缩图片的方法
    • 基于Asp.Net MVC4 Bundle捆绑压缩技术的介绍
    • asp.net SharpZipLib的压缩与解压问题
    • ASP.NET页面进行GZIP压缩优化的几款压缩模块的使用简介及应用测试!(附源码)
    • C#使用iCSharpcode进行文件压缩实现方法
    • asp.net C#实现解压缩文件的方法
    上一篇:ASP.NET取得所有颜色值示例
    下一篇:ASP.net中获取客户端参数操作系统信息
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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