明輝手游網(wǎng)中心:是一個免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

pb中壓縮整理access數(shù)據(jù)庫文件(mdb) 

[摘要]下面直接給出方法函數(shù): 1、申明外部函數(shù),用來取系統(tǒng)的臨時路徑。 FUNCTION ulong GetTempPath(ulong nBufferLength,ref string lpBuffer) LIBRARY "kernel32.dll" ALIAS FO...
       下面直接給出方法函數(shù):

       1、申明外部函數(shù),用來取系統(tǒng)的臨時路徑。  FUNCTION ulong GetTempPath(ulong nBufferLength,ref string lpBuffer) LIBRARY "kernel32.dll" ALIAS FOR "GetTempPathA"

      2、核心方法:

  global type gf_CompactAndRepairAccessDB from function_object
end type
forward prototypes
global function integer gf_compactandrepairaccessdb (string as_mdb)
end prototypes
global function integer gf_compactandrepairaccessdb (string as_mdb);
//檢查數(shù)據(jù)庫文件是否存在
if not FIleExists(as_MDB) then return -1
//創(chuàng)建臨時文件名
string ls_tmpFIle
ls_tmpFIle =Space(255)
GetTempPath(255,ls_tmpFIle)
ls_tmpFIle+="temp.mdb"
//創(chuàng)建DBEngine
integer result
oleobject ole_DBEngine
ole_DBEngine = create oleobject
result =ole_DBEngine.connecttonewobject("JRO.JetEngine")
//創(chuàng)建失敗
if  result<>0 then return result
//通過DBEngine 壓縮數(shù)據(jù)庫文件
string sProvider = 'Provider=Microsoft.Jet.OLEDB.4.0;'
string sOldMDB,sNewMDB
sOldMDB = sProvider + 'Data Source= ' + as_MDB
sNewMDB = sProvider + 'Data Source= ' + ls_tmpFIle
ole_DBEngine.CompactDatabase(sOldMDB, sNewMDB)
destroy ole_DBEngine
//拷貝剛剛壓縮過臨時數(shù)據(jù)庫文件至原來位置
FIleCopy(ls_tmpFIle,as_MDB,true)
//刪除臨時文件
FileDelete(ls_tmpFIle)
return 0
end function

    3、調(diào)用方法  

gf_compactandrepairaccessdb("E:\eNo\collect.mdb")



       應(yīng)注意的是,在壓縮和修復(fù)數(shù)據(jù)庫的過程中,不能有其它的操作打開該數(shù)據(jù)庫,否則操作會失敗,因此請先關(guān)閉掉該數(shù)據(jù)庫的連接,否則執(zhí)行會報(bào)錯。

       此外這個函數(shù)經(jīng)過修改后,可實(shí)現(xiàn)備份數(shù)據(jù)庫的功能,相比較更簡單一些,這里就不提供了。