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

資料庫訊息

答題得分者是:Fishman
baygon
一般會員


發表:20
回覆:31
積分:10
註冊:2003-10-03

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-12-30 10:29:03 IP:210.200.xxx.xxx 未訂閱
資料庫SQL-Server 新增時如鍵值重複,出現的訊息如何讓它不出現,而出現自己所要顯示的訊息。 非得一定在資料庫上改嗎??
Fishman
尊榮會員


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-12-30 10:43:19 IP:210.65.xxx.xxx 未訂閱
Hi:    
procedure TForm1.Button2Click(Sender: TObject);
begin
    TRY
        Table1.Post;
    EXCEPT
    END;
end;    procedure TForm1.Table1PostError(DataSet: TDataSet; E: EDatabaseError;
  var Action: TDataAction);
begin
    ShowMessage('Your Error Message');
end;
 
-------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman
Fishman
尊榮會員


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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-12-30 10:50:27 IP:210.65.xxx.xxx 未訂閱
Hi:    Sorry !! 漏了一句
procedure TForm1.Table1PostError(DataSet: TDataSet; E: EDatabaseError;
  var Action: TDataAction);
begin
//    ShowMessage(E.Message);  -- > 系統的 Message
    ShowMessage('Your Erro Message !!');
    Action := daAbort;
end;
-------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman
baygon
一般會員


發表:20
回覆:31
積分:10
註冊:2003-10-03

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-12-30 10:55:54 IP:210.200.xxx.xxx 未訂閱
這樣子原來系統的錯誤訊息還是會出現。 (無法在物件上插入重複的索引鍵)。
terrychen
尊榮會員


發表:90
回覆:794
積分:501
註冊:2003-05-01

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-12-30 11:01:51 IP:61.221.xxx.xxx 未訂閱
您好:
    DM.BuConnection.BeginTrans;
    try
      DM.factory.Post;
      DM.BuConnection.CommitTrans;
    except
    on E:Exception do
    begin
      DM.BuConnection.RollbackTrans;
      if Pos('Attempt to insert duplicate key row',E.Message)>0 then //假設當資料重複時資料庫回傳的錯誤訊有以上字串....
        raise Exception.Create('新增的資料已經存在')
      else
        raise Exception.Create('資料儲存失敗,錯誤訊息如下:'#13 E.message);
      end;
Fishman
尊榮會員


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

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-12-30 11:09:52 IP:210.65.xxx.xxx 未訂閱
Hi:    你所指的原先的錯誤訊息還事會出現 Tools->Decugger Options 中,將 Integrated debugging 勾選掉即可,即使不勾掉,在執行 exe 檔時,也不會有錯誤訊息 -------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman
baygon
一般會員


發表:20
回覆:31
積分:10
註冊:2003-10-03

發送簡訊給我
#7 引用回覆 回覆 發表時間:2003-12-30 11:33:30 IP:210.200.xxx.xxx 未訂閱
hi: 謝謝二位的熱情解答 二種方法都是可行的,我原本的用法是類似terrychen的方法 原來有daabort可用...呵呵!!! 那另有一問 像儲存的時候會發生的情況實在太多了,所以就直接讓它show系統訊息而不寫自己所要呈現的訊息嗎? 可訴使用者不懂還是一直打電話來問...
Fishman
尊榮會員


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

發送簡訊給我
#8 引用回覆 回覆 發表時間:2003-12-30 13:23:00 IP:210.65.xxx.xxx 未訂閱
Hi:    你可以整理一下常見的錯誤,用你自己的訊息予以替代,其它的直接顯示系統產生的錯誤訊息    有人曾說過,百分之九十的程式碼是用來防呆的,講的真是一多都沒錯 -------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman
系統時間:2024-11-23 6:00:45
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!