-
Данные в базе Oracle хранятся в unicode в нац. языке.
Пробую соединится через BDE, ADO, TOraSession. Во всех случях
данные искажаются (отображаются ???) уже в соответствующих Query компонентах, так что они не выводятся не в компонентах поддерживающие unicode, не в стандартных компонентах после преобразования.
-
> Пробую соединится через BDE, ADO, TOraSession.
про BDE забудь, не поддерживает unicode, что говорится у нутрях, и ничего с этим не поделать.
ADO пойдет, но обертки (грид/дбедиты/...) нужно менять, VCL также не поддерживает unicode, но есть замена компоненты TNT (так называлась бесплатная версия, ищи их).
пробовал access + ADO + TNT. получается.
TOraSession про него ничего не знаю, скорее тоже поддерживает, если он более менее новый, но про "обертки" и для него все в силе.
-
Может быть в ADO надо настроить параметры? Можете подсказать?
-
нечего не надо, кроме того что уже написал...
-
> gog © (29.05.09 14:41) [2]
>
> Может быть в ADO надо настроить параметры? Можете подсказать?
>
>
Забыть про свойство ToString и использовать свойство Value.
-
Я через через TNT-компоненты отображал данные из NCHAR, NVARCHAR колонок. Именно через ADO (ADOTable, если что)
-
Я забираю данные из БД с помощью TADOQuery SELECT–ом, а потом
пробовал заполнить TNTStringGrid кодом Cells[i,j]:= FieldByName('Some_Field').Value
или записать вTNTEdit аналогичным методом но ничего не получается. Одни ???.
Проверил прямой набор с клавиатуры в элементы, всё нормально, Copy Past тоже правильно работает, а вот SELECT никак.
-
Вообще странно, потому что ??? - это больше похоже на результат преобразования из юникода в Ansi.
-
> gog © (29.05.09 17:26) [6]
Попробуй подключить к TNTDBGrid.
-
Я тоже так думаю, проверил DataType соответствующего набора (FieldByName('Some_Field').DataType), он равен ftString, а не ftWideString. По тому думаю, что может быть надо как то настроить TADOConnection. У TOraSession есть параметр UseUnicode. Перевел его в True но никакого результата.
-
> Попробуй подключить к TNTDBGrid.
Пробовал, тот же результат
-
> gog © (29.05.09 18:20) [10]
Показывай строку подключения. Только без домыслов, а обычным copy-paste.
-
На всякий случай я покажу :)
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
-
> Показывай строку подключения. Только без домыслов, а обычным
> copy-paste.
Provider=MSDAORA.1;Password=sutg;User ID=utg_select;Data Source=bccdb
-
-
К сожалению Я не знаю немецкий, но в строке подключения добавил Unicode=True, результат старый. Может быть значение имеет Regional Settings? Они у меня стоят Russian
-
> Может быть значение имеет Regional Settings? Они у меня
> стоят Russian
гадать можно долго. обычно приводится проблемный код, структура таблицы, настройки Oracle на клиенте...
-
-
1) Дернуть pl/sql developer и убедиться что ошибка повторяется
2) Если повторяется - лезть в реестр и исправлять параметр NLS_LANG