在网页上进行Access数据库压缩

  次阅读 作者:智能小宝 来源:互联网 2016-01-28 13:21 我要评论(0)

多年前给客户做的数据库,用得是 access,已经两年,长得非常大,有 1G这么大。随着您不断添加、更新数据以及更改数据库设计,数据库文件会变得越来越大。导致增大的因素不仅包括新数据,随着数据库文件不断被遗留的临时对象和已删除对象所填充,其性能也会逐渐降低。其症状包括:对象可能打开得更慢,查询可能比正常情况下运行的时间更长,各种典型操作通常似乎也需要使用更长时间。

所以对access数据库进行压缩也是势在必行。

实在是会担心,如果不小心坏了,那可是救都救不回来。还好,备份一个 access 的数据库非常简单,就把那个档案复制一份,就解决了。甚至,还可以写一个aspx 网页,来执行这个动作,让我在任何地方,只要有网络,就可以用网页来做备份,就算我用iPad,iPhone,Android手机都可以。虽然是小题大作,一年不过做个两、三次的事,但是,若能够不让客户担心的情况下,做完这些保险的事,也会有让他们信任的感受。就算不是计算机自动化地来做,至少也是我自动地做,也算是自动化了啊!

但是,只有备份,仍然不够,备份只解决了失效复原的第一步。接下来面临的是旧数据越来越多,如果不删除,档案越来越大,查询的时间越来越长,真的是无谓的浪费时间。所以,接下来完成了删除旧数据的功能。但是,这又产生一个不满足。虽然,数据删了,查询速度又回复以往的快速,但是,数据文件的大小,仍然维持一样。着实想想真是不开心。

使用 office access,可以把 mdb打开,然后在「主功能(左上的窗口)」->「管理」->「压缩及修复数据库」这个功能,把数据库压缩。

这么做,就需要人工来做。并且要准备一台装有 MS access 的计算机才行。

当然这工作,用指令也行,但还是要在装有 MS access 的计算机执行指令,然后用工作排程器执行(参考)。

C:\Program Files (x86)\Microsoft Office\Office12\MSACCESS.EXEc:\Northwind.mdb /compact

这种若要想用网页执行,则会因为某种限制而无法执行。猜测主要是因为 MSACCESS.exe是桌面程序。执行后就卡住,没有把工作做完。这应该只是设定的问题,因为在开发环境是可以正常使用。但是在 IIS 的环境,就是卡祝有人提醒 service程序也许不能与桌面互动而导致问题(参考)。我试过这方法也是失败。我们以前尝试过,如果是 console 程序,是可以的执行成功的。

为了坚持要用网页执行,寻找许久,在微软的开发环境里,都会安装一个 dao。它只是一个 dll。只要把 dao.dll 复制一份在 bin里面,然后引用它。只要用两行就搞定了。

dao.DBEngine dbe = new DBEngine();

dbe.CompactDatabase(target_uncompact, target_compact, null, null,null);

如果,老板问,为什么两行程序要写快两个星期,那……,要请曹操的好朋友来回答了。

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...