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

請教 dbnavigator key villation 的問題

答題得分者是:l630521
shangju
一般會員


發表:30
回覆:14
積分:8
註冊:2002-03-13

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-05-10 10:00:19 IP:220.134.xxx.xxx 未訂閱
請教 按dbnavigator 的 inset or flash or post 鍵時 若鍵值重覆時 有key violation message 請教如何抓 這個 錯誤 以便改成中文message 提醒用戶 感恩告知 謝謝
l630521
資深會員


發表:15
回覆:349
積分:372
註冊:2003-02-17

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-05-10 10:13:06 IP:210.66.xxx.xxx 未訂閱
是否可改在TDataSet之OnPostError上做處理? Ian
shangju
一般會員


發表:30
回覆:14
積分:8
註冊:2002-03-13

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-05-10 10:49:18 IP:211.22.xxx.xxx 未訂閱
試 在 onposterr 做 仍然 不行 不過仍然 謝謝啦
shangju
一般會員


發表:30
回覆:14
積分:8
註冊:2002-03-13

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-05-10 11:06:13 IP:61.220.xxx.xxx 未訂閱
procedure Tusermanage.usertabPostError(DataSet: TDataSet; E: EDatabaseError; var Action: TDataAction); begin showmessage ('人名重覆'); { abort; } end; 不行的原因是 會一直重覆 show 人名重覆 有沒有 abort 都一樣 按dbnaviagtor 任何鍵都一樣 奇怪???
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#5 引用回覆 回覆 發表時間:2004-05-10 11:23:31 IP:210.65.xxx.xxx 未訂閱
Hi shangju,    如同 l630521 大大所言,於 TDataSet之OnPostError上做處理
procedure TForm1.Table1PostError(DataSet: TDataSet; E: EDatabaseError;
  var Action: TDataAction);
begin
    IF COPY(E.Message,1,14) = 'Key violation.' THEN
        BEGIN
            ShowMessage('主鍵值重覆!!');
        END
    ELSE
        BEGIN
            ShowMessage(E.Message);
        END;
    Action := daAbort;
end;
---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ----------------------------------
------
Fishman
系統時間:2024-06-29 23:49:04
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!