[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