Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  21:34[Войти] | [Зарегистрироваться]
Ответ на вопрос № 35406

07-09-2005 01:25
Добрый день!
Столкнулся со следущей проблемой: работаю с MSServer через ADO. На клиенте установлен W2000 pro. Если в региональных настройках установлен English (UK) при установленном Default Language = Russian, весь русский тескт при попадании в базу превращается в абра-кадабру. Если установить в рег. настройках Russian, все нормально.
Перепробовал все разумные возможности - ничего не помагает. При чем искажение происходит именно на клиенте, я коннектился через ODBC и смотрел логи.
Очень нужна помощь!
Спасибо

[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

22-09-2005 13:11
Только с пакетами это не будет работать, чуть поправить придётся. Вообще надо бы это как "Камень" оформить, а то довольно много вопросов с чем то похожем на это баг. Например эти:
http://www.delphikingdom.com/asp/answer.asp?IDAnswer=35406
http://www.delphikingdom.com/asp/answer.asp?IDAnswer=35247
http://www.delphikingdom.com/asp/answer.asp?IDAnswer=22356
http://www.delphikingdom.com/asp/answer.asp?IDAnswer=21764
http://www.delphikingdom.com/asp/answer.asp?IDAnswer=33138
http://www.delphikingdom.com/asp/answer.asp?IDAnswer=16254
http://www.delphikingdom.com/asp/answer.asp?IDAnswer=25872
http://www.delphikingdom.com/asp/answer.asp?IDAnswer=35735

22-09-2005 12:54 | Сообщение от автора вопроса
Огромное спасибо. Я над этой проблемой кучу сил и времени угрохал. Благодаря вам она решена

15-09-2005 15:47
Это глюк с DefaultUserCodePage прочесть про него можно тут http://qc.borland.com/wc/qcmain.aspx?d=8565 а исправить без перекомпиляции VCL можно так:

function GetDefaultUserCodePageAddr:PInteger;
type
  TCode=packed record
    CallOpA:Byte;
    OffsetA:Integer;
    CallOpB:Byte;
    OffsetB:Integer;
    MovOp:Byte;
    VarAddr:Pointer;
  end;
  TCodes=packed record
    Code1:TCode;
    JMP:Word;
    Code2:TCode;
  end;
var
  Code:^TCodes;
  Count:Integer;
  MemInfo:TMemoryBasicInformation;
begin
  Result:=nil;
  if (VirtualQuery(TObject,MemInfo,SizeOf(MemInfo))<SizeOf(MemInfo))
    or(MemInfo.State<>MEM_COMMIT) then Exit;
  Code:=MemInfo.BaseAddress;
  Count:=MemInfo.RegionSize;
  while Count>0 do begin
    with Code^ do
      if (Code1.CallOpA=$E8)and(Code1.CallOpB=$E8)and(Code1.MovOp=$A3)
        and(Code2.CallOpA=$E8)and(Code2.CallOpB=$E8)and(Code2.MovOp=$A3)
        and(Code1.OffsetA-Code1.OffsetB=Code2.OffsetA-Code2.OffsetB)
        and(Code1.VarAddr=Code2.VarAddr) then begin
        Result:=Code1.VarAddr;
        Break;
      end;
    Inc(PByte(Code));
  end;
end;


И где нибудь в initialization

  GetDefaultUserCodePageAddr^:=CP_ACP;


15-09-2005 14:48 | Сообщение от автора вопроса
Я обнаружил на каком этапе возникает глюк : попробовал сконвертнуть Ansi строку содержащую русский текст в Unicode с помощью функции StringToWideChar( или VarToOleStr) - получается та самая абра-кадабра. Т.е. Ado на каком-то этапе проводит такую конвертацию.
Почему такое может быть?

12-09-2005 00:25
Вряд ли глюк в ADO. Хотя можно проверить - установите последнюю версию MDAC, если все заработает нормально, то так оно и есть.
Кроме того, ADO - один из лучших способов доступа к MS SQL Server, хотя бы потому, что поддерживается Microsoft. В принципе, можно работать и через dbExpress (он тоже базируется на OLE DB).

09-09-2005 10:27 | Сообщение от автора вопроса
Client Network utility не помогла .
Попробовал сделать небольшой тестик на dbExpress компонентах - все рабоает нормально. Глюк все-таки где-то внутри ADO реализации.
Есть ли хотя бы какой -нибудь альтернативный набор компонент для SqlServer, проверенный и бесплатный ?

08-09-2005 00:36
"Use international settings" в Client network utility - Что это такое?
Client network utility - это утилита, входящая в состав клиента для SQL-сервера. "Use international settings" ("Использовать интернациональные настройки") - чекбокс на одной из закладок.

07-09-2005 12:21 | Сообщение от автора вопроса
Анатолий, я не преобразовываю из русского в английский. Я пытаюсь всавить русский текст в базу. Проблема в использующихся кодовых страницах, которые непонятно почему менются от установленного Regional settings, хотя не должны (должен влиять Default language). Видимо глюк где в ADo, потому что в BDE я никогда с подобными проблемами не сталкивался. Тем более что через ту же Management Console русский текст совершенно нормально заносится.
>Use international settings" в Client network >utility - Что это такое?

07-09-2005 11:49
Нельзя преобразовать из русского в английский, там просто нет табких сивмовлов, а Юникод VCL не поддерживает.

07-09-2005 03:43 | Вопрос к автору: запрос дополнительной информации
"Use international settings" в Client network utility тоже не помогает?

Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
Жили у бабуси два веселых гуся. Один белый, другой КАКОЙ?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования