Russian Qt Forum
Ноябрь 24, 2024, 04:43
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
Кодировка MySQL. Вопрос новичка
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Кодировка MySQL. Вопрос новичка (Прочитано 3639 раз)
toggetit
Гость
Кодировка MySQL. Вопрос новичка
«
:
Апрель 01, 2009, 10:43 »
Добрый день.
Работаю с Qt 4.4.3 в Ubuntu 8.10. Версия MySQL 5.0.67. Всё из репозиториев. Системная кодировка на сколько я понял - Utf8. При создании/просмотре баз через консоль русские символы отображаются корректно. Из написанных приложений Qt - "кракозябры".
Подскажите как исправить ситуацию
P.S. Порывшись по форуму нашёл такой рецепт:
QTextCodec *codec = QTextCodec::codecForName("UTF8");
QTextCodec::setCodecForTr(codec);
QTextCodec::setCodecForCStrings(codec);
QTextCodec::setCodecForLocale(codec);
непомогает.
P.P.S. В будующем необходимо будет хранить данные в cp-1251.
P.P.P.S. Буду благодарен за любые советы.
Записан
crackedmind
Гость
Re: Кодировка MySQL. Вопрос новичка
«
Ответ #1 :
Апрель 01, 2009, 11:45 »
Выполнить запросы, подставив нужную кодировку. Вроде бы должно помочь. Давно это было, плохо помню
Цитировать
SET NAMES 'charset_name'
SET CHARACTER SET charset_name
Записан
toggetit
Гость
Re: Кодировка MySQL. Вопрос новичка
«
Ответ #2 :
Апрель 01, 2009, 14:00 »
Всмысле? Я же и так знаю что всё в UTF8. Нужно заставить Qt отображать правильно
т.е. в какой тогда Qt отображает?
P.S. Не заработало - те же каракули (РуÑÑкий)
«
Последнее редактирование: Апрель 02, 2009, 14:42 от toggetit
»
Записан
toggetit
Гость
Re: Кодировка MySQL. Вопрос новичка
«
Ответ #3 :
Апрель 02, 2009, 15:18 »
ПРОБЛЕМА решилась следующим способом:
Опытным путём было установлено что в MySQL базы создаются ПО-УМОЛЧАНИЮ с ключом DEFAULT CHARSET latin1. Отсюда весь геморрой
добавляем строку "default-character-set=utf8" в /etc/mysql/my.cnf в блоке [mysqld] и наслаждаемся!!!
«
Последнее редактирование: Апрель 02, 2009, 15:43 от toggetit
»
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...