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

Вниз

Прочитать unicode данные из Oracle   Найти похожие ветки 

 
gog ©   (2009-05-29 13:47) [0]

Данные в базе Oracle хранятся в unicode в нац. языке.
Пробую соединится через BDE, ADO, TOraSession. Во всех случях
данные искажаются (отображаются ???) уже в соответствующих Query компонентах, так что они не выводятся не в компонентах поддерживающие unicode, не в стандартных компонентах после преобразования.


 
sniknik ©   (2009-05-29 14:15) [1]

> Пробую соединится через BDE, ADO, TOraSession.
про BDE забудь, не поддерживает unicode, что говорится у нутрях, и ничего с этим не поделать.

ADO пойдет, но обертки (грид/дбедиты/...) нужно менять, VCL также не поддерживает unicode, но есть замена компоненты TNT (так называлась бесплатная версия, ищи их).
пробовал access + ADO + TNT. получается.

TOraSession про него ничего не знаю, скорее тоже поддерживает, если он более менее новый, но про "обертки" и для него все в силе.


 
gog ©   (2009-05-29 14:41) [2]

Может быть в ADO надо настроить параметры? Можете подсказать?


 
sniknik ©   (2009-05-29 15:35) [3]

нечего не надо, кроме того что уже написал...


 
Плохиш ©   (2009-05-29 16:52) [4]


> gog ©   (29.05.09 14:41) [2]
>
> Может быть в ADO надо настроить параметры? Можете подсказать?
>
>

Забыть про свойство ToString и использовать свойство Value.


 
Игорь Шевченко ©   (2009-05-29 17:00) [5]

Я через через TNT-компоненты отображал данные из NCHAR, NVARCHAR колонок. Именно через ADO (ADOTable, если что)


 
gog ©   (2009-05-29 17:26) [6]

Я забираю данные из БД с помощью TADOQuery SELECT–ом, а потом
пробовал заполнить TNTStringGrid кодом Cells[i,j]:= FieldByName("Some_Field").Value
или записать вTNTEdit аналогичным методом но ничего не получается. Одни ???.
Проверил прямой набор с клавиатуры в элементы, всё нормально, Copy Past тоже правильно работает, а вот SELECT никак.


 
Игорь Шевченко ©   (2009-05-29 17:53) [7]

Вообще странно, потому что ??? - это больше похоже на результат преобразования из юникода в Ansi.


 
Плохиш ©   (2009-05-29 18:17) [8]


> gog ©   (29.05.09 17:26) [6]

Попробуй подключить к TNTDBGrid.


 
gog ©   (2009-05-29 18:18) [9]

Я тоже так думаю, проверил DataType соответствующего набора (FieldByName("Some_Field").DataType), он равен ftString, а не ftWideString. По тому думаю, что может быть надо как то настроить TADOConnection. У TOraSession есть параметр UseUnicode. Перевел его в True но никакого результата.


 
gog ©   (2009-05-29 18:20) [10]


> Попробуй подключить к TNTDBGrid.


Пробовал, тот же результат


 
Плохиш ©   (2009-05-29 18:22) [11]


> gog ©   (29.05.09 18:20) [10]

Показывай строку подключения. Только без домыслов, а обычным copy-paste.


 
Игорь Шевченко ©   (2009-05-29 18:26) [12]

На всякий случай я покажу :)

 object ADOConnection: TADOConnection
   Connected = True
   ConnectionString =
     "Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=u" +
     "ser;Data Source=orca"
   Provider = "OraOLEDB.Oracle.1"
   Left = 44
   Top = 16
 end


 
gog ©   (2009-05-29 18:26) [13]


> Показывай строку подключения. Только без домыслов, а обычным
> copy-paste.


Provider=MSDAORA.1;Password=sutg;User ID=utg_select;Data Source=bccdb


 
Плохиш ©   (2009-05-29 18:58) [14]


> gog ©   (29.05.09 18:26) [13]

Вот здесь http://msdn.microsoft.com/de-de/library/cc627448.aspx
упоминают
; Unicode="True"


 
gog ©   (2009-06-01 09:56) [15]

К сожалению Я не знаю немецкий, но в строке подключения добавил Unicode=True, результат старый. Может быть значение имеет Regional Settings? Они у меня стоят Russian


 
Игорь Шевченко ©   (2009-06-01 10:37) [16]


> Может быть значение имеет Regional Settings? Они у меня
> стоят Russian


гадать можно долго. обычно приводится проблемный код, структура таблицы, настройки Oracle на клиенте...


 
sniknik ©   (2009-06-01 11:16) [17]

> К сожалению Я не знаю немецкий
так почему бы не переключить страничку на родной для тебя язык? вроде -
http://msdn.microsoft.com/zh-cn/library/cc627448.aspx


 
ANB   (2009-06-03 14:45) [18]

1) Дернуть pl/sql developer и убедиться что ошибка повторяется
2) Если повторяется - лезть в реестр и исправлять параметр NLS_LANG



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

Форум: "Базы";
Текущий архив: 2010.08.27;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.48 MB
Время: 0.065 c
2-1273137388
Новичек1
2010-05-06 13:16
2010.08.27
вопрос по Set of


15-1267705960
Kolan
2010-03-04 15:32
2010.08.27
Где взять справку по TMaskEdit?


15-1273860812
AKE
2010-05-14 22:13
2010.08.27
Согласитесь, что нехватает оператора типа a < x < b


2-1274079491
pro_xaoc
2010-05-17 10:58
2010.08.27
удаление последнего символа


15-1271160223
Медвежонок Пятачок
2010-04-13 16:03
2010.08.27
нас ждет еще один капец





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский