Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.11.21;
Скачать: CL | DM;

Вниз

Поиск по всем полям!!!   Найти похожие ветки 

 
Настенька   (2004-10-23 08:46) [0]

Сделала такую вещь. Есть один едит и dbgrid. С помощью запроса ищется по всем полям таблицы то, что введено в едит. Вот мой запрос:
на событие onchange у едита

var sql:string; i,kol:byte;
begin
Sql:="select * from table1 where ";
for kol:=0 to DBGrid1.Columns.Count-1 do
begin
Sql:=Sql+"cast (" +DBGrid1.Columns[kol].FieldName+ " as varchar(30)) like "%"+edit1.text+"%"";
if kol < DBgrid1.Columns.Count-1 then sql:=sql+ " or ";
end;
Q1.Close;
Q1.SQL.Clear;
Q1.SQL.Add(sql);
Q1.Open;

Тут все круто работает: но вот в чем проблема. Он все поля приводит к cast, но мне не надо, чтобы он приводил стринговые поля, так как в них и без cast прекрасно ищется. Что сделать?


 
DSKalugin ©   (2004-10-23 16:28) [1]

переписать процедуру поиска ВПРИЦИПЕ!
А механизм поиска построить на использовании функции Locate()


 
Vlad ©   (2004-10-23 16:38) [2]


> Он все поля приводит к cast, но мне не надо, чтобы он приводил
> стринговые поля, так как в них и без cast прекрасно ищется.
> Что сделать?

Ну и в чем проблема? if then написать не можем?
А про DataType я вам кажется говорил.


 
Настенька   (2004-10-24 08:55) [3]

я делала так:
Sql:="select * from table1 where ";
for kol:=0 to DBGrid1.Columns.Count-1 do
begin
if query1.fields[i].datatype=ftinteger then
Sql:=Sql+"cast (" +DBGrid1.Columns[kol].FieldName+ " as varchar(30)) like "%"+edit1.text+"%""
else Sql:=Sql+""+DBGrid1.Columns[kol].FieldName+" like "%"+edit1.text+"%""
if kol < DBgrid1.Columns.Count-1 then sql:=sql+ " or ";
end;

но это не очень работает. что не так?


 
ЮЮ ©   (2004-10-25 03:04) [4]

if стринговое поле then
 не приводить
else
 приводить

далеко не соответствует вашему

if целое поле then
 приводить
else
 не приводить

>но это не очень работает. что не так?
не очень - это как?



Страницы: 1 вся ветка

Текущий архив: 2004.11.21;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.032 c
9-1090400471
1stGame
2004-07-21 13:01
2004.11.21
VCL или нет?


1-1099484048
Cosinus
2004-11-03 15:14
2004.11.21
Хм... OnDrawCell работает не так, как задумано.


14-1099481328
Mike Kouzmine
2004-11-03 14:28
2004.11.21
Буш победил


1-1099817308
Wood
2004-11-07 11:48
2004.11.21
Обращение к TMenuItem


4-1096961128
Lera
2004-10-05 11:25
2004.11.21
Обмен между приложениями.