Ruslan Polupan
Nov. 12, 2019, 8:11 p.m.

QString UTF8 -> WIN1251

QString, UTF8, winndows1251

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

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

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

5

Do you like it? Share on social networks!

15
R
  • Nov. 12, 2019, 8:17 p.m.

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

    Алексей Внуков
    • Nov. 12, 2019, 8:18 p.m.
    • (edited)

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

      Ruslan Polupan
      • Nov. 13, 2019, 1:19 a.m.

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

        Ruslan Polupan
        • Nov. 13, 2019, 12:54 p.m.

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

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

            получем...

            Если так

            1. QTextCodec* codecW = QTextCodec::codecForLocale();

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

              IscanderChe
              • Nov. 13, 2019, 2:54 p.m.

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

                Ruslan Polupan
                • Nov. 13, 2019, 4:03 p.m.

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

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

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

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

                  IscanderChe
                  • Nov. 13, 2019, 4:32 p.m.

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

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

                    Ruslan Polupan
                    • Nov. 13, 2019, 4:51 p.m.

                    возможно..

                      Алексей Внуков
                      • Nov. 13, 2019, 4:58 p.m.
                      • (edited)

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

                        Алексей Внуков
                        • Nov. 13, 2019, 4:59 p.m.

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

                          Ruslan Polupan
                          • Nov. 13, 2019, 5:41 p.m.

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

                            Алексей Внуков
                            • Nov. 14, 2019, 3:06 p.m.

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

                              Ruslan Polupan
                              • Nov. 14, 2019, 3:23 p.m.

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

                                Comments

                                Only authorized users can post comments.
                                Please, Log in or Sign up
                                • Last comments
                                • AK
                                  April 1, 2025, 11:41 a.m.
                                  Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
                                • Evgenii Legotckoi
                                  March 9, 2025, 9:02 p.m.
                                  К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
                                • VP
                                  March 9, 2025, 4:14 p.m.
                                  Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
                                • ИМ
                                  Nov. 22, 2024, 9:51 p.m.
                                  Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                                • Evgenii Legotckoi
                                  Oct. 31, 2024, 11:37 p.m.
                                  Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup