像Windows 一樣地查詢 (轉)

amyz發表於2007-08-15
像Windows 一樣地查詢 (轉)[@more@]

+ 5 + SERVER2K 編譯透過,執行正常。

const
  sMAIN_SQL = ' ...FROM ... WHERE (...)'  //用到別名,故下有"A.fItemNo"等
  sEMPTY = '';
  sITEM_TYPE = 'fItemType';

procedure SelectStock;
var
  stItemNo, stItemName, SQL: string;
begin
 adsStock.Active := False;
  SQL := sMAIN_SQL;
  adsStock.CommandText := SQL;

  if Trim(edtItemNo.Text) <> sEMPTY then
  begin
  stItemNo := StringReplace(Trim(edtItemNo.Text), '*', '%', [rfReplaceAll]);
  SQL := SQL + ' AND A.fItemNo like ''' + stItemNo + '''';
  adsStock.CommandText := SQL;
  end;

  if Trim(edtItemName.Text) <> sEMPTY then
  begin
  stItemName := StringReplace(Trim(edtItemName.Text), '*', '%', [rfReplaceAll]);
  SQL := SQL + ' AND A.fItemName like ''' + stItemName + '''';
  adsStock.CommandText := SQL;
  end;

  if cbbItemType.Text <> sEMPTY then
  begin
  SQL := SQL + ' AND B.fItemType = :fItemType ';
  adsStock.CommandText := SQL;
  adsStock.Parameters.ParamByName(sITEM_TYPE).Value := cbbItemType.Text;
  end;
  ......// 其他條件
  adsStock.Active := True;
end;
這樣,如果使用者不輸入任何限制條件,則按sMAIN_SQL查詢出結果。一旦使用者輸入類似於"1-*05*"等形式的條件,將執行類似於查詢一樣的模糊查詢。


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752019/viewspace-958282/,如需轉載,請註明出處,否則將追究法律責任。

相關文章