Главная страница
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.04 c
6-1091719190
kirasuki
2004-08-05 19:19
2004.10.10
Режимы TServerSocket


9-1086797256
karlsn
2004-06-09 20:07
2004.10.10
ии в игре типа "генералов"


3-1095160139
/glokk
2004-09-14 15:08
2004.10.10
вьювы из хп :(


14-1095625033
Владимир Савельев
2004-09-20 00:17
2004.10.10
требуется программист для написания прокси под win32


3-1093344909
_jk_
2004-08-24 14:55
2004.10.10
inceremental fetch tclientdataset баг?