全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1431
推到 Plurk!
推到 Facebook!

DbiPackTable問題

尚未結案
a120803
初階會員


發表:61
回覆:66
積分:25
註冊:2003-03-12

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-04-07 09:17:03 IP:163.25.xxx.xxx 未訂閱
請問各位大大: 我是要pack foxpro table,而我的foxpro table的欄位名稱是中文,在程式執行時出現錯誤:table is busy running,能告訴我為什麼嗎 Table1,Close; Table1.Exclusive=true; Table1,Open; DbiPackTable(Table.DBHandle,Table.Handle,nil,szFOXPRO,True); //出錯處 Table1,Close; Table1.Exclusive=False;
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-04-07 09:33:27 IP:202.39.xxx.xxx 未訂閱
參考: http://www.priv.bus.at/graf/quell/delphiarchives/bdehlp32/1jhszru.htm http://www.glisp.com.cn/feel/pack.htm --- 每個人都是一本書 發表人 - hagar 於 2003/04/07 09:41:17
P.D.
版主


發表:603
回覆:4038
積分:3874
註冊:2006-10-31

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-04-07 22:15:26 IP:61.66.xxx.xxx 未訂閱
引言: 請問各位大大: 我是要pack foxpro table,而我的foxpro table的欄位名稱是中文,在程式執行時出現錯誤:table is busy running,能告訴我為什麼嗎 Table1,Close; Table1.Exclusive=true; Table1,Open; DbiPackTable(Table.DBHandle,Table.Handle,nil,szFOXPRO,True); //出錯處 Table1,Close; Table1.Exclusive=False;
請把 TABLE1.OPEN移除, 執行PACK時是不可以OPEN的, 因為 DBIPACKTABLE 會自動對OPEN做處理機制!
a120803
初階會員


發表:61
回覆:66
積分:25
註冊:2003-03-12

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-04-11 01:46:29 IP:163.25.xxx.xxx 未訂閱
謝謝大大: 我也把Table.Open拿掉ㄌ,可是並無法做到pack功能,被刪的紀錄在Visual Foxpro底下還是看的到 不知道是不是BDE不支援Foxpro還是還要加入一些程式來執行
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-04-11 07:19:37 IP:202.39.xxx.xxx 未訂閱
引言: 謝謝大大: 我也把Table.Open拿掉ㄌ,可是並無法做到pack功能,被刪的紀錄在Visual Foxpro底下還是看的到 不知道是不是BDE不支援Foxpro還是還要加入一些程式來執行
這是 help 中關於 dbiPackTable 中的 pszDriverType 參數的一段: pszDriverType Type: pCHAR (Input) Pointer to the driver type. Optional. This parameter is required if pszTableName has no extension. The only valid pszDriverType is szDBASE. --- 每個人都是一本書
a120803
初階會員


發表:61
回覆:66
積分:25
註冊:2003-03-12

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-04-12 01:13:23 IP:163.25.xxx.xxx 未訂閱
謝謝大大: 那是不是只適用於DBASE而不適用於FOXPRO啊 我用的的是Visual Foxpro 6
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#7 引用回覆 回覆 發表時間:2003-04-12 07:20:38 IP:202.39.xxx.xxx 未訂閱
引言: 謝謝大大: 那是不是只適用於DBASE而不適用於FOXPRO啊 我用的的是Visual Foxpro 6
把 pszDriverType 參數值改成 szDBASE 試試 不過我沒用過, 也沒有東西可以試. --- 每個人都是一本書
a120803
初階會員


發表:61
回覆:66
積分:25
註冊:2003-03-12

發送簡訊給我
#8 引用回覆 回覆 發表時間:2003-04-14 08:20:15 IP:163.25.xxx.xxx 未訂閱
謝謝大大: 有把參數設訂成szDBASE,可是還是不行ㄝ
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#9 引用回覆 回覆 發表時間:2003-04-14 09:00:59 IP:202.39.xxx.xxx 未訂閱
還是一樣的錯誤訊息嗎? 以下是參考連結中的方法:
procedure PackTable(Table: TTable);
var
  Props: CURProps;
  hDb: hDBIDb;
begin
  if not Table.Active then
    raise EDatabaseError.Create('Table 須已開啟');
   
  if not Table.Exclusive then
    raise EDatabaseError.Create('Table 須以獨占方式開啟');
   
  Check(DbiGetCursorProps(Table.Handle, Props));
  if (Props.szTableType = szDBASE) then
    Check(DbiPackTable(Table.DBHandle, Table.Handle, nil, szDBASE, True))
  else
    raise EDatabaseError.Create('Table必需是 dBASE 或 FoxPro 類型');
   
  Table.Open;
end;
--- 每個人都是一本書
系統時間:2024-07-05 5:04:50
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!