日期格式輸入錯誤,為何用Validate不會先檢查到? |
尚未結案
|
shinhrn
中階會員 發表:54 回覆:165 積分:83 註冊:2002-06-05 發送簡訊給我 |
我用ACCSET資料庫,DELPHI7.0 為何設定了 Validate 系統還是會出現
的錯誤,難道欄位不能設成 DATETIME,要用字串? ADOQtable1d_fill: TDateTimeField; procedure TfrmOvertime_Manager.ADOQtable1d_fillValidate(
Sender: TField);
begin
IF NOT ChkStr_isDate(Sender.AsString) THEN
raise exception.create('日期輸入錯誤');
//沒有用
end;
|
hagar
版主 發表:143 回覆:4056 積分:4445 註冊:2002-04-14 發送簡訊給我 |
|
shinhrn
中階會員 發表:54 回覆:165 積分:83 註冊:2002-06-05 發送簡訊給我 |
引言: 在 IDE 內還是會出現如圖的錯誤訊息是正常的 直接執行 exe 檔就不會了, 否則在 delphi 選單 -> Tools -> Debugger Options 的 Language Exceptions 頁中 有個 Stop on Delphi Exceptions 的 checkbox 不打勾就好了. 另見: http://delphi.ktop.com.tw/topic.php?TOPIC_ID=22247 --- 每個人都是一本書. --<-<-<@我知道,可是我的情形是 我把 asccset 欄位 改成文字,Validate就有用, 欄位 改成 日期/時間 時,Validate就無效ㄝ,奇怪勒?不知為何 發表人 - shinhrn 於 2004/02/12 17:47:04 發表人 - shinhrn 於 2004/02/12 17:53:56 |
hagar
版主 發表:143 回覆:4056 積分:4445 註冊:2002-04-14 發送簡訊給我 |
|
shinhrn
中階會員 發表:54 回覆:165 積分:83 註冊:2002-06-05 發送簡訊給我 |
引言: 看情形是還沒觸發 OnValidate 就引發的錯誤訊息 您是用什麼元件輸入日期的? 有沒有其它檢查日期的地方? --- 每個人都是一本書. --<-<-<@我想也是,可是我又找不到,因為我不用改程式,只要將 asccset 欄位改成 文字就可以了ㄝ,我想是不是TDateTimeField 的問題? 因為我是過 procedure TfrmOvertime_Manager.ADOQtable1d_fillValidate( Sender: TField); begin showmessage('日期輸入錯誤'); end; 如果資料正確Validate有用,資料錯誤就直接error了Validate就不runㄝ 發表人 - |
T.J.B
版主 發表:29 回覆:532 積分:497 註冊:2002-08-14 發送簡訊給我 |
|
babyfish4
一般會員 發表:2 回覆:40 積分:18 註冊:2003-08-04 發送簡訊給我 |
您好: 可以試試將OnValiDate的Event寫在
OnSetText的Event裡頭
begin IF NOT ChkStr_isDate(Sender.AsString) THEN begin raise exception.create('日期輸入錯誤'); Abort; end; end; 引言: 我用ACCSET資料庫,DELPHI7.0 為何設定了 Validate 系統還是會出現 的錯誤,難道欄位不能設成 DATETIME,要用字串? ADOQtable1d_fill: TDateTimeField; procedure TfrmOvertime_Manager.ADOQtable1d_fillValidate( Sender: TField); begin IF NOT ChkStr_isDate(Sender.AsString) THEN raise exception.create('日期輸入錯誤'); //沒有用 end; |
shinhrn
中階會員 發表:54 回覆:165 積分:83 註冊:2002-06-05 發送簡訊給我 |
|
shinhrn
中階會員 發表:54 回覆:165 積分:83 註冊:2002-06-05 發送簡訊給我 |
|
babyfish4
一般會員 發表:2 回覆:40 積分:18 註冊:2003-08-04 發送簡訊給我 |
|
shinhrn
中階會員 發表:54 回覆:165 積分:83 註冊:2002-06-05 發送簡訊給我 |
引言:依現有狀況來看是如此,可是我認為要先ValiDate再Set這樣的順序才對阿,要不然ValiDate有何意義?? 另又試到一狀況提供大家參考,一般檢查datetime是用strtoDaTime()去try 可是ㄋ strtoDaTime('2004/02/02 aaa1:11:11')-->error strtoDaTime('2004/02/02 2aaa11:11:11')-->卻ok 可是入存到資料庫時就會error了..... 發表人 - shinhrn 於 2004/02/13 13:42:23引言:因為OnSetText會比OnValiDate先發生 所以會先攔截到引言: 您好: 可以試試將OnValiDate的Event寫在 OnSetText的Event裡頭可以ㄝ...3Q.........不知為何ValiDate沒有先檢查喔???ok.....3Q |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |