国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 課堂 > 技術開發 > 正文

使用pb中壓縮整理access數據庫文件

2023-06-15 12:15:02
字體:
來源:轉載
供稿:網友

本文講解了在PowerBuilder下壓縮數據庫的方法。

下面直接給出方法函數:

(1)申明外部函數,用來取系統的臨時路徑。  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);
        //檢查數據庫文件是否存在
        if not FIleExists(as_MDB) then return -1
             //創建臨時文件名
             string ls_tmpFIle
              ls_tmpFIle =Space(255)
              GetTempPath(255,ls_tmpFIle)
              ls_tmpFIle+="temp.mdb"
              //創建DBEngine
              integer result
oleobject ole_DBEngine
ole_DBEngine = create oleobject
result =ole_DBEngine.connecttonewobject("JRO.JetEngine")
//創建失敗
if  result<>0 then return result
//通過DBEngine 壓縮數據庫文件
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
//拷貝剛剛壓縮過臨時數據庫文件至原來位置
FIleCopy(ls_tmpFIle,as_MDB,true)
//刪除臨時文件
FileDelete(ls_tmpFIle)
return 0
end function

(3)調用方法

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

 應注意的是,在壓縮和修復數據庫的過程中,不能有其它的操作打開該數據庫,否則操作會失敗,因此請先關閉掉該數據庫的連接,否則執行會報錯。

 此外這個函數經過修改后,可實現備份數據庫的功能,相比較更簡單一些,這里就不提供了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 灯塔市| 攀枝花市| 玉田县| 嘉兴市| 三亚市| 疏附县| 云南省| 临潭县| 都匀市| 娄底市| 增城市| 车险| 达孜县| 许昌县| 墨玉县| 夏津县| 宜春市| 通道| 浑源县| 雅江县| 柳江县| 积石山| 商水县| 石棉县| 新津县| 石棉县| 林西县| 迁西县| 安西县| 淮安市| 开阳县| 琼海市| 巴南区| 麻阳| 监利县| 镇雄县| 崇明县| 厦门市| 友谊县| 财经| 杭锦后旗|