Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2004.10.10;
Скачать: [xml.tar.bz2];

Вниз

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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.037 c
10-1043680118
AlexanderSK
2003-01-27 18:08
2004.10.10
MIDAS (DataSnap) - WebConnection


14-1095768383
SergeySEM
2004-09-21 16:06
2004.10.10
Какое сегодня число


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


14-1095861531
Pavel__
2004-09-22 17:58
2004.10.10
USB


3-1094813399
Vilkkkka
2004-09-10 14:49
2004.10.10
Firebird & Interbase





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский