Ruslan Polupan
Ruslan Polupan12 ноября 2019 г. 9:11

QString UTF8 -> WIN1251

QString, UTF8, winndows1251

Доброго времени суток.
Задача: в базу данных Firebird в поле типа BLOB (содержит набор SQL запросов которые по расписанию выполнятся на базе данных) записать строки:

QString strSQL = "UPDATE FUELS SET NAME = 'ДП-З-Евро5-ВО' WHERE FUEL_ID = 7;";

Как сконвертировать strSQL в win1251?
я уже мозг сломал изучая примеры....
Буду благодарен....

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

15
R
  • 12 ноября 2019 г. 9:17

Добрий день, через QTextCodec

    Алексей Внуков
    • 12 ноября 2019 г. 9:18
    • (ред.)

    в параметре поля прописать колейт и нужную кодировку. больше конвертировать не нужно

      Ruslan Polupan
      • 12 ноября 2019 г. 14:19

      Если не затруднит можно пример кода....

        Ruslan Polupan
        • 13 ноября 2019 г. 1:54

        COLLATE к сожалению я менять не могу.

          IscanderChe
          • 13 ноября 2019 г. 2:11
          QTextCodec* codec1;
          QTextCodec* codec2;
          
          codec1 = QTextCodec::codecForName("UTF-8");
          codec2 = QTextCodec::codecForLocale();
          
          QString strSQL = "...";
          QByteArray byteArrayContent;
          byteArrayContent.insert(0, strSQL);
          strSQL = codec1->toUnicode(byteArrayContent);
          strSQL = codec2->fromUnicode(strSQL);
          
            Ruslan Polupan
            • 13 ноября 2019 г. 2:56
                int runScriptCroupID;
                QByteArray result;
                QTextCodec* codecU = QTextCodec::codecForName("UTF-8");
                QTextCodec* codecW = QTextCodec::codecForName("Windows-1251");
                result.insert(0, strSQL);
                strSQL = codecU->toUnicode(result);
                strSQL = codecW->fromUnicode(strSQL);
                QSqlQuery q;
                q.exec("SELECT GEN_ID(GEN_RUNSCRIPTSGROUPS,1) FROM RDB$DATABASE");
                q.next();
                runScriptCroupID = q.value(0).toInt();
                q.finish();
                foreach (int terminalID, m_terminals) {
                    q.prepare("INSERT INTO RUNSCRIPTS (TERMINAL_ID, RUNSCRIPT_ID, RUNSCRIPTSGROUP_ID, CONNECT_ID, RUNDAT, SQLDATA, NEED_RESTART, APPLY, ISERROR, RESTARTMSG, RUNSRIPT_TYPE, DPROCESSED) "
                                   "VALUES (:terminalID, GEN_ID(GEN_RUNSCRIPTS,1), :runScriptGroupID, 2, :scriptDate, :script, 'F', 'F', 'F', '', 0, NULL)");
                    q.bindValue(":terminalID", terminalID);
                    q.bindValue(":runScriptGroupID",runScriptCroupID);
                    q.bindValue(":scriptDate", ui->dateEdit->date().toString("yyyy-MM-dd ")+"23:15:00");
                    q.bindValue(":script" , strSQL);
                    if(!q.exec()) qCritical(logCritical()) << "Не возможно добавить скрипт для АЗС" << terminalID << q.lastError().text();
                }
            

            получем...

            Если так

            QTextCodec* codecW = QTextCodec::codecForLocale();
            

            То получаем следующее:

              IscanderChe
              • 13 ноября 2019 г. 3:54

              А можно эти кракозябры сюда в виде текста скопировать? Или самостоятельно прогоните их через эту приблуду, посмотрите что из чего кодится.

                Ruslan Polupan
                • 13 ноября 2019 г. 5:03

                Начнем сначала :-)
                Перекодировку не используем.
                Вот как отвображается BLOB в интерефейсе сторонней программы там ГВОЗДЯМИ 1251.

                вот так отображается текст если я его сюда вставляю из буфера
                ?”?Y-?—-?•??N€??5-?’?z

                А вот так реагирует декодер

                Что-то я совсем заблудился....

                  IscanderChe
                  • 13 ноября 2019 г. 5:32

                  Судя по скринам, и до кодировки и после кодировки одни и те же значения в BLOBе оказываются для "ДП-3-Евро5-ВО". Как так?

                  Пример, который привёл я, рабочий. В своё время написал перекодировщик файлов из Windows-1251 в UTF-8 и обратно, всё работает успешно. Возможно, что-то особенное на стороне БД.

                    Ruslan Polupan
                    • 13 ноября 2019 г. 5:51

                    возможно..

                      Алексей Внуков
                      • 13 ноября 2019 г. 5:58
                      • (ред.)

                      а почему именно в BLOB? он предназначен в для хранения бинарных дынных, может стоит реализацию базы данных пересмотреть?

                        Алексей Внуков
                        • 13 ноября 2019 г. 5:59

                        я подозреваю что ситуация из-за использования поля не по назначению

                          Ruslan Polupan
                          • 13 ноября 2019 г. 6:41

                          Ну ка кбы уже лет 10 как работает :-)
                          Просто нужна отдельная прога для добавления таких записей, отдать клиентам чтобы мозг не парили....

                            Алексей Внуков
                            • 14 ноября 2019 г. 4:06

                            повторю: BLOB - это бинарник, хранить обыкновенную строку в BLOB - это не правильно. но даже если уже есть такая ситуация которую правильно сделать нельзя (и не важно что в сторонней проге кодировка гвоздями) - совет только копать в сторону преобразования бинарных данных в строку

                              Ruslan Polupan
                              • 14 ноября 2019 г. 4:23

                              Я уже понял это, ковыряюсь сижу....

                                Комментарии

                                Только авторизованные пользователи могут публиковать комментарии.
                                Пожалуйста, авторизуйтесь или зарегистрируйтесь
                                AD

                                C++ - Тест 004. Указатели, Массивы и Циклы

                                • Результат:50баллов,
                                • Очки рейтинга-4
                                m
                                • molni99
                                • 26 октября 2024 г. 1:37

                                C++ - Тест 004. Указатели, Массивы и Циклы

                                • Результат:80баллов,
                                • Очки рейтинга4
                                m
                                • molni99
                                • 26 октября 2024 г. 1:29

                                C++ - Тест 004. Указатели, Массивы и Циклы

                                • Результат:20баллов,
                                • Очки рейтинга-10
                                Последние комментарии
                                i
                                innorwall14 ноября 2024 г. 21:26
                                Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
                                i
                                innorwall14 ноября 2024 г. 19:03
                                Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
                                i
                                innorwall14 ноября 2024 г. 11:42
                                Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
                                i
                                innorwall14 ноября 2024 г. 9:09
                                Qt/C++ - Урок 068. Hello World с использованием системы сборки CMAKE в CLion ditropan pristiq dosing With the Yankees leading, 4 3, Rivera jogged in from the bullpen to a standing ovation as he prepared for his final appearance in Chicago buy priligy pakistan
                                Сейчас обсуждают на форуме
                                i
                                innorwall14 ноября 2024 г. 3:39
                                добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
                                i
                                innorwall11 ноября 2024 г. 10:55
                                Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                                9
                                9Anonim25 октября 2024 г. 9:10
                                Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
                                ИМ
                                Игорь Максимов3 октября 2024 г. 4:05
                                Реализация навигации по разделам Спасибо Евгений!

                                Следите за нами в социальных сетях