zoukankan      html  css  js  c++  java
  • paip.编程压缩Access数据库

    paip.编程压缩Access数据库


    作者Attilax ,  EMAIL:1466519819@qq.com 
    来源:attilax的专栏
    地址:http://blog.csdn.net/attilax


    /命令行法
    "d:\Program Files\Microsoft Office\OFFICE12\MSACCESS.EXE" /compact  "D:\locoySpiderv8\Data\LocoySpider\48\SpiderResult.mdb" 
    会出来个BLASH闪一挂.




    com方法
    况且有时候需要自动来完成这个操作,所以我们需要把它用代码来完成,需要调用COM对象的方法,压缩后的数据库被保存为另外一个文件,再把原文件删除(其实Access自己也是这么做的),代码如下:


    #include "objbase.h" //牵涉到COM对象,必须包含此头文件


    AnsiString srcmdb="c://test.mdb"; //原文件名(压缩之前)
    AnsiString destmdb="c://test2.mdb"; //目标文件名(压缩之后)
    CoInitialize(NULL); //初始化COM对象
    AnsiString src = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+srcmdb; //连接字串
    AnsiString dest = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+destmdb;
    Variant AdoObj = Variant::CreateObject("JRO.JetEngine");
    AdoObj.OleProcedure("CompactDatabase",src.c_str(),dest.c_str());
    AdoObj.Clear();
    CoUninitialize();
    DeleteFile(srcmdb) ; //删除原文件,如果不放心可以不删除留个备份,但需要改名
    RenameFile(destmdb,srcmdb); //将压缩后的文件改成原文件名




    参考:
    Access启动命令行选项_开发 数据库_IT专家网.htm
    如何压缩Access数据库 - _ Compile Failed _ - 博客频道 - CSDN_NET
    How to use command-line switches in Microsoft Access.htm
  • 相关阅读:
    web常用自动化库——selenium总结(转)
    前端框架面试题
    SpringBoot整合Knife4j展示更美观的API文档
    JUC- ThreadLocal学习笔记
    JUC-ThreadPool线程池的使用与学习
    Java8 新特性
    SpringBoot 整合FreeMarker进行邮件发送
    IDEA 打开别人的项目的是Maevn插件依赖出错问题处理
    Liunx常用指令备查
    第四次作业
  • 原文地址:https://www.cnblogs.com/attilax/p/15199464.html
Copyright © 2011-2022 走看看