Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.04.08;
Скачать: [xml.tar.bz2];




Вниз

использование UPPER в SQL-запросах 


Siberia   (2002-03-11 17:43) [0]

пишу что-то типа:

str:="select * from table where UPPER(table_field) LIKE "%"+AnsiUpperCase(Edit1.Text)+"%";

DM.Query.SQL.Clear;
DM.Query.SQL.Add(str);
DM.Query.Open;

работает со всеми нужными полями, а вот с полями типа MEMO - не работает не фига ...

Подскажите - есть ли другие способы добиться того чего надо, или че вообще делать-та ...

плизззз ...))))



JibSkeart   (2002-03-11 18:56) [1]

Хммм на скольео мне известно
помойму ему не важен регист

так как я обычно делаю даже так

ну простой пример в SQL

select * from table where field="test"

а запись у меня тама "TEST" !!

или еше
select * from table where field like "%test%"
тоже самое !!

находит



Siberia   (2002-03-12 10:07) [2]

Хммммм ... А почему же у меня реагирует на регистр ...

Если запись, допустим, "Алена", то "але" - он уже при помощи LIKE не находит ... Может это настраивается как-то ... Или чета я в парадоксе ему не сказала?



kserg@ukr.net   (2002-03-12 12:45) [3]

Когда то и я с этим сталкивался - оказалось, что UPPER(MEMO) не работает.
Пришлось извращаться типа
...where MemoField LIKE "%АЛЕНА%" OR MemoField LIKE "%Алена%"
OR MemoField LIKE "%алена%"

Более красивого решения не нашел.



Johnmen   (2002-03-12 13:06) [4]

Думаю, что UPPER для национальной кодировки не работает
(так же, как и в IB) - надо извращаться...



data   (2002-03-12 13:14) [5]

2 Johnmen © (12.03.02 13:06)
>Думаю, что UPPER для национальной кодировки не работает
>(так же, как и в IB) - надо извращаться...

В ИБ для текстовых полей работает. Только при создании таблицы для текстовых полей нужно указывать COLLATE PXW_CYRL и на всякий случай CHARACTER SET WIN1251 (если вдруг он в целом для всей БД не указан).



Johnmen   (2002-03-12 13:21) [6]

>data ©
>В ИБ для текстовых полей работает. Только при создании таблицы >для текстовых полей нужно указывать COLLATE PXW_CYRL и на >всякий случай CHARACTER SET WIN1251 (если вдруг он в целом для >всей БД не указан).

И все это заради UPPER"а ?




data   (2002-03-12 17:17) [7]

2 Johnmen © (12.03.02 13:21)
Collate заради Upper"a. А что, это так сложно? ;-)



TYuri   (2002-03-12 19:53) [8]

Напиши вот так все должно заработать

str:="select UPPER(table_field) from table where table_field LIKE "%"+AnsiUpperCase(Edit1.Text)+"%";



Siberia   (2002-03-14 10:21) [9]

> TYuri © (12.03.02 19:53)

Это работает с одной таблицей, а если с двумя - то конструкция типа:

str:="select N.*,Upper(N1.*) from name N, name1 N1 where ...."

уже не работает ... ((




Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.04.08;
Скачать: [xml.tar.bz2];




Наверх





Память: 0.73 MB
Время: 0.019 c
14-22833          Sks                   2002-02-28 09:45  2002.04.08  
Win API


3-22597           Shurasik              2002-03-18 13:42  2002.04.08  
Не могу найти событие для DBGrid...


4-22878           Nexus                 2002-02-03 16:58  2002.04.08  
Доступ к иконкам зарегестрированным в оболочке Windows


14-22797          Lotus                 2002-02-24 11:41  2002.04.08  
А сколько народу здесь на Билдере пишут?


1-22649           Locked                2002-03-28 10:17  2002.04.08  
XMLDoc