adoquery filter问题!(100分)

  • 主题发起人 主题发起人 qinzusong
  • 开始时间 开始时间
Q

qinzusong

Unregistered / Unconfirmed
GUEST, unregistred user!
adoquery.filter:='a字段=b字段';
adoquery.filtered:=true;
报错"参数类型不正确,或不在可接受的范围之内,或与其他参数冲突"
 
adoquery.sql.text:=' select a字段,b字段 from Ttable'
字段类型一样
我那个select 语句很慢,我返回时是没有条件的,在客户端进行筛选

adoquery.filter:='a字段=b字段';
adoquery.filtered:=true;
报"参数类型不正确,或不在可接受的范围之内,或与其他参数冲突" 字样错误。
 
过滤没有'a字段=b字段'这种用法,只能'a字段=Value' 或 'a字段>=Value'等等。
因此你需要过滤时可以用SQL语句代替。
adoquery.Close;
adoquery.sql.text:=' select a字段,b字段 from Ttable where a字段=b字段'
adoquery.Open;
 
To qinzusong
数据集的Filter属性只能使用“字段=值”的形式,不允许“字段=字段”形式。
例如:
ADOQuery1.Filter := 'a字段=' + QuotedStr('Value');
或是
ADOQuery1.Filter := 'a字段=' + QuotedStr('Value1') + 'OR' + 'a字段=' + QuotedStr('Value2');
 

Similar threads

S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
1K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
923
SUNSTONE的Delphi笔记
S
后退
顶部