Форум: "Базы";
Поиск по всему сайту: 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.028 c
3-22543           AlderMan              2002-03-15 11:24  2002.04.08  
Многомерные таблицы (OLAP)


3-22588           andreik               2002-03-01 15:03  2002.04.08  
Как в DBGrid запихнуть CheckBox?


3-22548           Atrem                 2002-03-13 20:00  2002.04.08  
Сортировка НД


1-22694           IronHawk              2002-03-26 14:58  2002.04.08  
Как сохранить текст из Едита в Файл без метки перевода каретки (конца строки)?


3-22585           Dust_                 2002-03-18 00:25  2002.04.08  
Сумма по подгруппе в отчете QReport