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

Вниз

UPPER и COLLATE   Найти похожие ветки 

 
PSN   (2004-09-09 00:51) [0]

Здравствуйте.
Помогите пожалуйста разобраться с логикой работы функции UPPER.

Есть таблица.
CREATE TABLE ARTICLES (
   TERMINAL_ID     T_TERMINAL,
   ARTICLE_ID      INTEGER NOT NULL,
   NAME            VARCHAR(24) NOT NULL COLLATE PXW_CYRL,
   NEWNAME         VARCHAR(24) NOT NULL
);


В полях NAME и NEWNAME храняться одинаковые значения.

Результаты следующих двух запросов разные.

select UPPER(NAME) from ARTICLES  Where UPPER(NAME) starting with UPPER(:NAME)
select UPPER(NEWNAME) from ARTICLES  Where UPPER(NEWNAME) starting with UPPER(:NAME)
Для поля NAME UPPER  приводит к верхнему регистру для NEWNAME нет.
Это и понятно - для NAME указан COLLATE. Но если и для NEWNAME указать COLLATE PXW_CYRL таким вот запросом:
update RDB$RELATION_FIELDS set RDB$COLLATION_ID = 1 where (RDB$FIELD_NAME = "NEWNAME") and RDB$RELATION_NAME = "ARTICLES")

то все равно UPPER не работает.
Подскажите какие пути решения есть для данной проблемы? Или COLLATE можно указывать только при создании таблицы?
Да и еще успользую FireBird 1.0.2.908

С уважением Прищепа Сергей.


 
Cobalt ©   (2004-09-09 00:57) [1]

Вообще-то, изменение полей логичнее делать ALTER Table


 
Zacho ©   (2004-09-09 01:01) [2]

COLLATE ожно указать непосредственно в запросе.
А вообще по работе с русскими буквами есть хорошая статья - http://www.ibase.ru/devinfo/ibrusfaq.htm


 
PSN   (2004-09-09 01:11) [3]

Спасибо большое Zacho © за статью  http://www.ibase.ru/devinfo/ibrusfaq.htm
помог следующий код UPDATE ARTICLES SET NEWNAME=NEWNAME
его нужно было выполнить после изменения COLLATE
update RDB$RELATION_FIELDS set RDB$COLLATION_ID = 1 where (RDB$FIELD_NAME = "NEWNAME") and RDB$RELATION_NAME = "ARTICLES")



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

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

Наверх




Память: 0.47 MB
Время: 0.024 c
1-1095303974
Kair()
2004-09-16 07:06
2004.10.10


4-1094818437
*Pavel
2004-09-10 16:13
2004.10.10
Странности чтения с СОМ порта


4-1094730245
FGH
2004-09-09 15:44
2004.10.10
Debug API


4-1094650844
Новишок
2004-09-08 17:40
2004.10.10
Закрыть программку, нажав на кнопу в сыоей проге


6-1090419041
banderas
2004-07-21 18:10
2004.10.10
Как определить IP отконнективающегося клиента (idTCPClient)