線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:552
推到 Plurk!
推到 Facebook!

關於Filter的問題

尚未結案
anitawu
一般會員


發表:1
回覆:1
積分:0
註冊:2004-09-14

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-09-14 17:08:13 IP:220.134.xxx.xxx 未訂閱
我是用 SQL Server 2K with Delphi 4.0 請問如何用filter 篩選 datetime 試了很多種方式 不是出現 capatable的錯誤訊息 就是 invalid field的錯誤訊息 with table1 do begin dt :='2004/09/14'; if Active then Active:=false; if CheckBox1.checked then begin S := 'LoginDate=' QuotedStr(dt); Filter:=S; end; open; end;
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-09-14 18:19:05 IP:202.62.xxx.xxx 未訂閱
您好﹗    請先檢查一下日期簡短格式﹐Filter中需使用相同的日期格式﹐設定方法如下﹕ http://delphi.ktop.com.tw/topic.php?TOPIC_ID=56185    ========================= 大病初愈﹐休養調整中... =========================
------
忻晟
Chance36
版主


發表:31
回覆:1033
積分:792
註冊:2002-12-31

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-09-17 01:32:33 IP:203.204.xxx.xxx 未訂閱
anitawu 你好
  或許可以考慮從Table1.OnFilterRecord事件來解決比較好
procedure TForm1.Table1FilterRecord(DataSet: TDataSet;
  var Accept: Boolean);
Var
  dt : TDate;
begin
  dt :=StrToDate('2004/09/14');
  Accept := True;
  if CheckBox1.checked then begin
    Accept := (Trunc(DataSet.FieldByName('LoginDate').AsDateTime) = dt);
  End;
end;    然後在Table1.Open;之後,需要時一樣把Filtered設為True;即可。
_______________________________________ 深藍的魚,祝您好運..........連連
anitawu
一般會員


發表:1
回覆:1
積分:0
註冊:2004-09-14

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-10-02 11:28:35 IP:220.134.xxx.xxx 未訂閱
引言: 我是用 SQL Server 2K with Delphi 4.0 請問如何用filter 篩選 datetime 試了很多種方式 不是出現 capatable的錯誤訊息 就是 invalid field的錯誤訊息 with table1 do begin dt :='2004/09/14'; if Active then Active:=false; if CheckBox1.checked then begin S := 'LoginDate=' QuotedStr(dt); Filter:=S; end; open; end;
結果後來發現 是大小寫問題 =___=
系統時間:2024-07-01 9:43:33
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!