![]() |
|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
||||
|
||||
![]() Здравствуйте. Помогите пожалуйста очень прощу.
При добавлений записи в таблицу вместо казахских букв отображается вопросительный знак. Таблица в Mysql. Подключаюсь к базе через fdconnection. Запись добавляю через fdquery. Вот такой код использую для добавление записи: Код:
Код:
|
#2
|
|||
|
|||
![]() А если каким-нить сторонним тулом глянуть в БД? Там правильно отображается или тоже кракозябры? Очень уж похоже, что проблема на стороне базы данных, там надо задать дефолтную кодировку для полей при создании полей.
|
Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
Aibekkoke (09.02.2024)
|
#3
|
|||
|
|||
![]() Цитата:
|
#4
|
|||
|
|||
![]() А если конвертнуть в AnsiString с нужной кодировкой? Убери установку utf-8 и при встаке конвертируй строки в нужную кодировку. Может поможет...
|
Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
Aibekkoke (09.02.2024)
|
#5
|
|||
|
|||
![]() Цитата:
|
#6
|
|||
|
|||
![]() Кстати, а какая кодовая страница стоит по умолчанию?
Посмотри значение в System.DefaultSystemCodePage Если неправильная, то вызови метод System.SetMultiByteConversionCodePage для установки правильной кодировки. |
Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
Aibekkoke (09.02.2024)
|
#7
|
|||
|
|||
![]() Цитата:
ShowMessage('Текущая кодовая страница: ' + IntToStr(System.DefaultSystemCodePage)); показывает 1251 System.SetMultiByteConversionCodePage(65001); Потом пробовал установить utf-8, тогда вместо букв какие кракозябры появилось. И еще если записать данные из dbgrid тогда все буквы нормально отображается. А если добавить из edit-ов и combobox-ов тогда вместо казахских букв вопросительный знак. Не знаю что делать теперь:-( |
#8
|
|||
|
|||
![]() Ну, 1251 - это русская кодировка.
Я не знаю, для казахских букв существует отдельная кодировка или они должны быть частью русской. Еще 2 момента. Я бы проверил кодировку для не-юникодных программ в Windows (это настройка). Потом посмотри (попробуй) в TEdit в св-ве Font поставить нужный чрасет, может там собака порылась... |
Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
Aibekkoke (09.02.2024)
|
#9
|
|||
|
|||
![]() Цитата:
А если использовать базу данных acsess тогда все отлично добавляется. Не знаю уже что делать. Сколько дней сижу ![]() ![]() ![]() |
#10
|
|||
|
|||
![]() Теперь работает:
Form3.FDQuery1.ParamByName('tabel').DataType := ftWideString; Form3.FDQuery1.ParamByName('tabel').AsString := WideString(Edit1.Text); |
#11
|
|||
|
|||
![]() Ага, как и предполагалось, где-то идет конвертация в AnsiString с неправильной кодовой страницей. Только вот я не ожидал, что она в параметрах происходит.
Кстати, переводить Edit1.Text в WideString, наверное, не обязательно. Дефолтный String, который на самом деле UnicodeString полностью совместим с WideString (собственно, это один и тот же тип). Т.о. можно сделать что-то типа: Код:
|
Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
Aibekkoke (09.02.2024)
|
#12
|
|||
|
|||
![]() Кстати, а какая кодовая страница стоит по умолчанию?
Посмотри значение в System.DefaultSystemCodePage Если неправильная, то вызови метод System.SetMultiByteConversionCodePage для установки правильной кодировки. Последний раз редактировалось Aristarh Dark, 04.03.2024 в 15:57. |