用我的函数 Function CompactAndRepair(sOldMDB:String;sNewMDB:String;psw:string;password:boolean):Boolean; const sProvider='Provider=Microsoft.Jet.OLEDB.4.0;'; var oJetEng:JetEngine; begin if password then sOldMDB:=sProvider+'Data Source='+sOldMDB+';jet oledb:database password="'+psw+'"' else sOldMDB:=sProvider+'Data Source='+sOldMDB;
if password then sNewMDB:=sProvider+'Data Source='+sNewMDB+';jet oledb:database password="'+psw+'"' else sNewMDB:=sProvider+'Data Source='+sNewMDB; try oJetEng:=CoJetEngine.Create; oJetEng.CompactDatabase(sOldMDB, sNewMDB); oJetEng:=Nil; Result:=True; except oJetEng:=Nil; Result:=False; end; end; {10.CompactAndRepair(压缩Access数据库,用到JRO_TLB单元,可按下面方法加入) } { a) 在Delphi IDE中选择Project - Import Type Library. } { b) 往下翻直到你找到“Microsoft Jet and Replication Objects 2.1 Library”.}
onclick事件中调用的例子(菜单里的,不是你所要求的btn,但我想应该是一样的吧):procedure Tmainform.N31Click(Sender: TObject); begin if application.MessageBox('压缩数据库可以节省硬盘空间,但系统的性能可能会略微下降,确实要压缩数据库吗?','询问',mb_yesno+mb_defbutton2+mb_iconquestion)=idyes then begin datamodule1.ADOConnection1.Connected:=false; if CompactAndRepair('junhua.9sky', 'junhua1.mdb','jiutiankaifabuchupin',true) then begin if copyfile('junhua1.mdb','junhua.9sky',false) then deletefile('junhua1.mdb'); ShowMessage('数据库压缩成功!系统即将关闭。'); application.Terminate; end else ShowMessage('压缩数据库出错!'); end; end;
var
dao:OLEVariant;
tstr1,tstr2:string;
winpath:pchar;
begin
my_locate_conn.Close;
GetMem(WinPath,255);
GetWindowsDirectory(WinPath,255);
Tstr1:=WinPath;
dao:=CreateOleObject('DAO.DBEngine.36');
Tstr2:=Tstr1+'\_tem5.bak';
Tstr1:=Tstr1+'\_tem5.tem'; //解密后的文件--正常文件
dao.CompactDatabase(tstr1,tstr2);
deletefile(tstr1);
RenameFile(tstr2,tstr1);
tstr2:=ExtractFilePath(ParamStr(0))+'db\l_song.mdb';
你看看吧,这就可以了,但在使用前要将 DAO360。DLL注册,这个文件在安装OFFICE2000后会自动注册
另外,你怎么把他写在Form的Closequery事件里。我不明白!谢谢你!
Function CompactAndRepair(sOldMDB:String;sNewMDB:String;psw:string;password:boolean):Boolean;
const
sProvider='Provider=Microsoft.Jet.OLEDB.4.0;';
var
oJetEng:JetEngine;
begin
if password then
sOldMDB:=sProvider+'Data Source='+sOldMDB+';jet oledb:database password="'+psw+'"'
else
sOldMDB:=sProvider+'Data Source='+sOldMDB;
if password then
sNewMDB:=sProvider+'Data Source='+sNewMDB+';jet oledb:database password="'+psw+'"'
else
sNewMDB:=sProvider+'Data Source='+sNewMDB;
try
oJetEng:=CoJetEngine.Create;
oJetEng.CompactDatabase(sOldMDB, sNewMDB);
oJetEng:=Nil;
Result:=True;
except
oJetEng:=Nil;
Result:=False;
end;
end; {10.CompactAndRepair(压缩Access数据库,用到JRO_TLB单元,可按下面方法加入) }
{ a) 在Delphi IDE中选择Project - Import Type Library. }
{ b) 往下翻直到你找到“Microsoft Jet and Replication Objects 2.1 Library”.}
begin
if application.MessageBox('压缩数据库可以节省硬盘空间,但系统的性能可能会略微下降,确实要压缩数据库吗?','询问',mb_yesno+mb_defbutton2+mb_iconquestion)=idyes then
begin
datamodule1.ADOConnection1.Connected:=false;
if CompactAndRepair('junhua.9sky', 'junhua1.mdb','jiutiankaifabuchupin',true) then
begin
if copyfile('junhua1.mdb','junhua.9sky',false) then
deletefile('junhua1.mdb');
ShowMessage('数据库压缩成功!系统即将关闭。');
application.Terminate;
end
else
ShowMessage('压缩数据库出错!');
end;
end;
http://www.delphibbs.com/delphibbs/dispq.asp?lid=1268352
分类:数据库-文件型 ( 版主:hbezwwl, 吴剑明 )
来自:ysai, 时间:2002-8-16 10:56:00, ID:1268352 | 编辑 [显示:小字体 | 大字体]
看到很多富翁提出类似问题,给出一个比较好的解决方法
第一个参数为原始数据库文件名(完整路径),第二个参数为密码
修改后可以实现压缩后与压缩前有不同的密码!
//引用ComObj,ActiveX
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;
我编译通过了,但压缩失败,CompactAndRepair('junhua.9sky', 'junhua1.mdb','jiutiankaifabuchupin',true)括号内的东西不明白,给讲解一下好吗,我备份与恢复功能是正常的,说明数据库没有被使用。