Поиск:

Ответ в темуСоздание новой темы Создание опроса
> ODAC и кодировка, проблемы с insert 
:(
    Опции темы
underchronos
Дата 15.6.2010, 15:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 37
Регистрация: 25.7.2008

Репутация: нет
Всего: нет



Использую ODAC, Delphi 2009, Oracle 10g
Direct := true;
UseOCI7 := false;

Коннект такого вида:
Код

  OS_.Options.Charset := 'CL8MSWIN1251';
  OS_.Options.DateLanguage := 'RUSSIAN';
  ConnectWith_ := true;
  try
    OS_.ConnectString:= user + '/' + psw + '@192.168.0.4:1521:TEST';
    OS_.Connected:=true;


Код

select * from nls_database_parameters
PARAMETER    VALUE
NLS_CHARACTERSET    CL8MSWIN1251
NLS_CALENDAR    GREGORIAN
NLS_DATE_FORMAT    DD.MM.RR
NLS_DATE_LANGUAGE    RUSSIAN
NLS_SORT    RUSSIAN
NLS_TIME_FORMAT    HH24:MI:SSXFF
NLS_TIMESTAMP_FORMAT    DD.MM.RR HH24:MI:SSXFF
NLS_TIME_TZ_FORMAT    HH24:MI:SSXFF TZR
NLS_TIMESTAMP_TZ_FORMAT    DD.MM.RR HH24:MI:SSXFF TZR
NLS_DUAL_CURRENCY    ?.
NLS_COMP    BINARY
NLS_LENGTH_SEMANTICS    BYTE
NLS_NCHAR_CONV_EXCP    FALSE
NLS_NCHAR_CHARACTERSET    AL16UTF16
NLS_RDBMS_VERSION    10.2.0.1.0


Все хорошо селектся. Русские символы и т.п. Но когда передаю через параметры String, заносится примерно такое: D>=8=0 
PM MAIL   Вверх
Akella
Дата 15.6.2010, 16:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



А ты что, разве не в курсе, что D2009 - это юникодная IDE?
PM MAIL   Вверх
underchronos
Дата 15.6.2010, 17:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 37
Регистрация: 25.7.2008

Репутация: нет
Всего: нет



Akella
Цитата(Akella @  15.6.2010,  16:42 Найти цитируемый пост)
А ты что, разве не в курсе, что D2009 - это юникодная IDE?

Это знание мне жизнь не облегчает. 
NLS_NCHAR_CHARACTERSET    AL16UTF16 разве не поддерживает стандарт unicode?
PM MAIL   Вверх
Akella
Дата 15.6.2010, 20:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



Цитата(underchronos @  15.6.2010,  15:41 Найти цитируемый пост)
OS_.Options.Charset := 'CL8MSWIN1251';

Ты же указываешь, что кодировка подключения в Win1251. А данные в базу отправляешь в юникоде. Так?
PM MAIL   Вверх
Citytramp
Дата 23.10.2010, 16:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 2.10.2006

Репутация: нет
Всего: нет



Наверное, лучше не создавать новую тему, потому что всё очень похоже:

Использую DOA, Delphi 7, Oracle 9i.

В реестре:
HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0\nls_lang=RUSSIAN_CIS.CL8MSWIN1251

Данные на русском языке записываются и отображаются правильно. Но!
На одном компьютере сообщения об ошибках (например, если потеряна связь с БД) выдаются на русском, а на другом компьютере - в крокозябрах. (В реестре одно и тоже). Если меняю в реестре кодировку на AMERICAN_AMERICA , то сообщения выдаются на английском, как и следовало ожидать, но пользователям надо на русском.

Если это важно, то вот что возаращает запрос:
select * from nls_database_parameters

Код

NLS_NCHAR_CHARACTERSET    AL16UTF16
NLS_LANGUAGE             AMERICAN
NLS_TERRITORY            AMERICA
NLS_CURRENCY             $
NLS_ISO_CURRENCY         AMERICA
NLS_NUMERIC_CHARACTERS    .,
NLS_CHARACTERSET         CL8MSWIN1251
NLS_CALENDAR             GREGORIAN
NLS_DATE_FORMAT          DD-MON-RR
NLS_DATE_LANGUAGE        AMERICAN
NLS_SORT                 BINARY
NLS_TIME_FORMAT          HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT     DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT       HH.MI.SSXFF AM TZR
NLS_TIMESTAMP_TZ_FORMAT    DD-MON-RR HH.MI.SSXFF AM TZR
NLS_DUAL_CURRENCY        $
NLS_COMP                 BINARY
NLS_LENGTH_SEMANTICS     BYTE
NLS_NCHAR_CONV_EXCP      FALSE
NLS_RDBMS_VERSION        9.2.0.8.0

Но дело в настройках не сервера, а клиента, т.к. БД одна, а на разных компах сообщения выдаются по-разному.

Где посоветуете покопать? Интернет уже перерыт, не помогло. 

Это сообщение отредактировал(а) Citytramp - 23.10.2010, 16:45
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.0628 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.