[Comm] QT3, MySQL и русские буквы
Alexander Dymo
=?iso-8859-1?q?cloudtemple_=CE=C1_mksat=2Enet?=
Вс Мар 30 01:35:13 MSK 2003
On Saturday 29 March 2003 20:09, Прокопьев Евгений wrote:
> Здравствуйте!
>
> Вот прочитал раздел Creating Database Applications в QT Assistant и
> решил попробовать.
>
> Создал табличку author следующего содержания:
>
> +----+----------+-----------+
>
> | id | forename | surename |
>
> +----+----------+-----------+
>
> | 1 | Ivan | Petrov II |
> | 16 | ???? | ??????? |
> | 12 | Petr | Filippov |
> | 17 | Федя | Хрюков |
>
> +----+----------+-----------+
>
> Приложение (просто отображающую таблицу) нарисовал в QT Designer, кода в
> нем кроме main практически нет. Все сделал по умолчанию.
>
> Последняя строка (добавленная через утилиту mysql) в QT-приложении
> выглядит так:
>
> +----+----------+-----------+
>
> | 17 | ?A*A"N~ | e`O`A`E"I"? |
>
> +----+----------+-----------+
>
> А строка 16 была добавлена с помощью приложения, но сразу после нажатия
> Enter превратилась в вопросительные знаки.
>
> Собственно вопрос: как бороться с русскими буквами в QT-приложениях,
> работающих с MySQL? Куда хотя бы копать? Если QT ожидает увидеть в MySQL
> юникод, то как его туда ввести?
Надо унаследоваться от QDataTable, переопределив
paintField( QPainter * p, const QSqlField * field,
const QRect & cr, bool selected),
где следует значение field->value с помощью QTextCodec
перекодировать из кодировки MySql (обычно koi8-r, cp1251, utf-8)
в Unicode. Это решит проблему отображения.
С вводом можно поступить аналогичным образом, по сигналам
void beforeInsert ( QSqlRecord * buf )
void beforeUpdate ( QSqlRecord * buf )
в собственном слоте произвести обратный процесс перекодировки
значений каждого поля с типом QVariant::String и QVariant::CString
из Unicode в то, что хочет видеть MySql.
После этого создать QtDesigner plugin для переопределенной
таблицы и радоваться жизни ;)
Если в базе cp866, то нужно писать еще QTextCodecPlugin
для этой кодировки.
С PostgreSQL, кстати, процедура гораздо проще. Если клиент
скомпилирован с поддержкой Unicode и установлено
SET CLIENT_ENCODING=UNICODE,
а также на сервере база создана с опцией -E UNICODE,
то Qt эту ситуацию понимает и без всяких телодвижений позволяет
вводить хоть китайские иероглифы:).
C Oracle все примерно так же, как и с PostgreSQL. Другие СУБД не
пробовал.
--
Alexander Dymo
Ukrainian State Maritime Technical University, IT Department
Подробная информация о списке рассылки community