用程序实现压缩access(*.mdb)数据库的方法.

王朝delphi·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

下面的函数用来压缩access数据库 需要增加ComObj单元

function CompactDatabase(AFileName,APassWord:string):boolean;

//压缩与修复数据库,覆盖源文件

const

SConnectionString = 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=%s;'

+'Jet OLEDB:Database Password=%s;';

var

SPath,SFile:Array [0..254] Of Char;

STempFileName:String;

JE:OleVariant;

begin

GetTempPath(40,SPath);//取得Windows的Temp路径

GetTempFileName(SPath,'~CP',0,SFile);//取得Temp文件名,Windows将自动建立0字节文件

STempFileName:=SFile;//PChar->String

DeleteFile(STempFileName);//删除Windows建立的0字节文件

try

JE:=CreateOleObject('JRO.JetEngine');//建立OLE对象,函数结束OLE对象超过作用域自动释放

OleCheck(JE.CompactDatabase(format(SConnectionString,[AFileName,APassWord]),

format(SConnectionString,[STempFileName,APassWord])));//压缩数据库

//复制并覆盖源数据库文件,如果复制失败则函数返回假,压缩成功但没有达到函数的功能

result:=CopyFile(PChar(STempFileName),PChar(AFileName),false);

DeleteFile(STempFileName);//删除临时文件

except

result:=false;//压缩失败

end;

end;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航