8

我使用此代码过滤我的表:

Table.Filtered := False;
Table.Filter := '[' + Field_Search + '] LIKE ''%' + Edit_Search.Text + '%''';
Table.Filtered := True;

但它引发了这个例外:

“操作不适用。”

问题在哪里?

4

7 回答 7

12

ATTable.Filter不是 SQL 查询。LIKE不支持(也不支持IN)。根据文档,支持的运算符是=, <>, >, <, >=, '<= ,AND ,NOT andOR`

对于更复杂的过滤,使用TDataSet.OnFilterRecord事件:

procedure TForm1.Table1FilterRecord(Dataset: TDataset; var Accept: Boolean);
begin
  // Don't remember if D7 supports DataSet[FieldName] syntax; if not,
  // use DataSet.FieldByName instead, or a persistent field.
  Accept := Pos(Edit_Search.Text, DataSet[SearchField].AsString) > 0;
end;
于 2012-07-21T18:34:25.043 回答
3
Table.Filtered := False;
Table.Filter := Field_Search + ' LIKE ' + QuotedStr('*' + Edit_Search.Text + '*');
Table.Filtered := True;
于 2013-05-26T04:02:44.503 回答
2

你应该使用这个:

   DataModule.Table.Filtered := False;
   DataModule.Table.Filter := 'Field_Name' + ' LIKE ' + QuotedStr(Edt_SearchByCode.Text +'%');
   DataModule.Table.Filtered := True;

并且将像魔术一样工作,不再使用 TQuery .... 如果您想要 Matching 不考虑区分大小写。您应该改用此代码:

   DataModule.Table.Filtered := False;
   DataModule.Table.FilterOptions := [foCaseInsensitive];
   DataModule.Table.Filter := 'Field_Name' + ' LIKE ' + QuotedStr(Edt_SearchByCode.Text +'%');
   DataModule.Table.Filtered := True;
于 2018-04-10T17:19:18.643 回答
1

我发现这个主题正在寻找其他东西。我总是使用 TDataSet.OnFilterRecord 事件,在大多数情况下我使用 TEdit.OnChange 事件,所以搜索是“活动的”;

var
Criteria : string;
...
...

procedure TForm1.Edit1Change(Sender: TObject);
begin
  Table.Filtered := False;
  Criteria := Edit1.text;
  Table.Filtered := True;
end;

和 OnFilter 事件

procedure TForm1.TableFilterRecord(DataSet: TDataSet;
  var Accept: Boolean);
begin
  Accept := AnsiContainsStr(Table.Fields[xx].asString,Criteria);
end;

为我工作。

于 2021-11-12T12:24:08.517 回答
0

以下代码也可以正常工作

if Edit1.Text <>'' then
begin
Query1.Filter :='FieldName ='+quotedstr('*'+ edit1.Text +'*');
Query1.Filtered:=true;
end
else
begin query1.Filtered :=false; end;
于 2017-10-30T10:18:23.670 回答
0

我主要使用 TEdit 这里是代码

if (EditSerarch.Text <> '') then
begin
FDQQuery.Filtered := false;
FDQQuery.Filter:=   'Name LIKE'+ QuotedStr('%'+EditSerarch.Text+'%') +
            ' OR Company LIKE '+ QuotedStr('%'+EditSerarch.Text+'%') +
              ' OR Phone LIKE '+ QuotedStr('%'+EditSerarch.Text+'%') +
             ' OR Mobile LIKE '+ QuotedStr('%'+EditSerarch.Text+'%');
FDQQuery.Filtered:= True;
end else FDQQuery.Filtered := false;
于 2019-07-26T08:39:31.700 回答
-1

我建议使用 SQL 查询来执行此操作。

例子:

query1.SQL.Text:='Select * FROM table_name WHERE field like '+ QuotedStr(edit1.text+'%');
query1.Active:=true;
于 2013-11-01T16:35:19.983 回答