РС
Руслан Склюев18 июня 2020 г. 16:01

Простенький запрос

qt, DataBase, QML

Здравствуйте! Установил PG12.
Тестовый запрос: INSERT INTO "public"."NameTable" ("FirstName", "SurName", "Nik") VALUES ('ff', 'cc', 'bb');
Как реализовать его в query.prepare? ругается на кавычки.

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

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

19
Evgenii Legotckoi
  • 18 июня 2020 г. 16:18

Добрый день.
Нужно делать экранирование, поскольку кавычки в C++ это спец символы.

Напишите строку так

query.prepare("INSERT INTO \"public\".\"NameTable\" (\"FirstName\", \"SurName\", \"Nik\") VALUES ('ff', 'cc', 'bb');")
    РС
    • 18 июня 2020 г. 16:38

    "INSERT INTO \"public\".\"NameTable\" ( \"FisrtName\", \"SurName\", \"Nik\") VALUES (:db, 'cc', \"bb\")"
    "ОШИБКА: ошибка синтаксиса в конце\nLINE 1: EXECUTE \n ^\n(42601) QPSQL: Невозможно создать запрос"
    QML debugging is enabled. Only use this in a safe environment.

      Evgenii Legotckoi
      • 18 июня 2020 г. 16:41

      Показывайте полный код, как формируете запрос, в том числе и C++ код.

      P/S/ и когда будете вставлять в сообщение код, то воспользуйтесь диалогом для вставки кода, чтобы разметка правильно сформировалась.
      Это одна из кнопок в тулбаре редактора.

        Evgenii Legotckoi
        • 18 июня 2020 г. 16:49
        • (ред.)

        Будьте так любезны, вставляйте программный код с помощью этого дилога.
        У меня нет времени, чтобы перепечатывать ваш код с картинки, чтобы объяснить вам вашу ошибку.

          bool DataBase::inserIntoTable(const QVariantList &data)
          {
          
              QSqlQuery query;
          
             query.prepare("INSERT INTO \"public\".\"NameTable\" (\"FirstName\", \"SurName\", \"Nik\") VALUES ('ff', 'cc', 'bb');");
          
              if(!query.exec()){
                  qDebug() << "error insert into " << TABLE;
                  qDebug() <<  query.lastQuery();
                  qDebug() << query.lastError().text();
                  return false;
              } else {
                  return true;
              }
              return false;
          }
          
            Evgenii Legotckoi
            • 18 июня 2020 г. 16:54

            Какую ошибку выдаёт этот ваш запрос?
            Поскольку в предыдущем сообщении у вас был запрос, в котором вы пытались сделать bind

            и выглядел он иначе

            "INSERT INTO \"public\".\"NameTable\" ( \"FisrtName\", \"SurName\", \"Nik\") VALUES (:db, 'cc', \"bb\")"
            

              "INSERT INTO \"public\".\"NameTable\" ( \"FisrtName\", \"SurName\", \"Nik\") VALUES (:db, 'cc', \"bb\")"
              "ОШИБКА: ошибка синтаксиса в конце\nLINE 1: EXECUTE \n ^\n(42601) QPSQL: Невозможно создать запрос"
              QML debugging is enabled. Only use this in a safe environment.

                Evgenii Legotckoi
                • 18 июня 2020 г. 17:02

                Вот пример из документации

                QSqlQuery query;
                query.prepare("INSERT INTO person (id, forename, surname) "
                              "VALUES (:id, :forename, :surname)");
                query.bindValue(":id", 1001);
                query.bindValue(":forename", "Bart");
                query.bindValue(":surname", "Simpson");
                query.exec();
                

                Если вы пытаетесь сделать bind, то вам нужно правильно сформировать строку запроса, плюс указать bind привязки.

                В данном случае наличие кавычек уже не нужно будет.

                bool DataBase::inserIntoTable(const QVariantList &data)
                {
                
                    QSqlQuery query;
                
                   query.prepare("INSERT INTO public.NameTable (FirstName, SurName, Nik) VALUES (:db, 'cc', 'bb');");
                   query.bindValue(":db",       data[0].toString());
                
                    if(!query.exec()){
                        qDebug() << "error insert into " << TABLE;
                        qDebug() <<  query.lastQuery();
                        qDebug() << query.lastError().text();
                        return false;
                    } else {
                        return true;
                    }
                    return false;
                }
                

                В статье, по которой вы это делаете были макросы, поэтому для конкатенации строк нужно было делать разделение кавычками. А вы очевидно формируете запрос сразу без макросов.

                  error insert into  NameTable
                  "INSERT INTO public.NameTable (FirstName, SurName, Nik) VALUES ('ffb', 'cc', 'bb');"
                  "ОШИБКА:  ошибка синтаксиса в конце\nLINE 1: EXECUTE \n                ^\n(42601) QPSQL: Невозможно создать запрос"
                  
                    Evgenii Legotckoi
                    • 18 июня 2020 г. 17:20

                    Так, добро... А как себя поведёт такой код?

                    bool DataBase::inserIntoTable(const QVariantList &data)
                    {
                    
                        QSqlQuery query;
                    
                        query.prepare("INSERT INTO NameTable (FirstName, SurName, Nik) VALUES (:FName, :SName, :Nik)");
                        query.bindValue(":FName",       "Name");
                        query.bindValue(":SName",       "Surname");
                        query.bindValue(":Nik",         "Nik");
                    
                        if(!query.exec()){
                            qDebug() << "error insert into " << TABLE;
                            qDebug() <<  query.lastQuery();
                            qDebug() << query.lastError().text();
                            return false;
                        } else {
                            return true;
                        }
                        return false;
                    }
                    

                      error insert into public.NameTable
                      "INSERT INTO NameTable (FirstName, SurName, Nik) VALUES (:FName, :SName, :Nik)"
                      "ОШИБКА: ошибка синтаксиса (примерное положение: \"(\")\nLINE 1: EXECUTE ('Name', 'Surname', 'Nik')\n ^\n(42601) QPSQL: Невозможно создать запрос"

                      Ну теперь на значения ругается

                        Evgenii Legotckoi
                        • 18 июня 2020 г. 17:30

                        А это уже очень плохо. Данный вариант кода должен был сработать.
                        Или не создалась таблица, или драйвер QPSQL коряво отрабатывает с PG12.

                        Лучше будет, если таблицы нет.
                        В случае с драйвером писать на багтрекер Qt Company тикет об ошибке и откатываться на более старую версию PG

                          На PG запрос должен выглядеть так INSERT INTO "public"."NameTable" ("FirstName", "SurName", "Nik") VALUES ('ff', 'cc', 'bb')

                            Evgenii Legotckoi
                            • 18 июня 2020 г. 17:38

                            Тогда это должно было сработать - ссылка на комментарий

                            Также наличие public не принципиально, как и наличие кавычек

                            Сами документацию на PostgreSQL 12 почитайте, вот ссылка на INSERT

                            А вот пример из документации

                            INSERT INTO films (code, title, did, date_prod, kind)
                                VALUES ('T_601', 'Yojimbo', 106, '1961-06-16', 'Drama');
                            

                              У меня получилось, если создать строку, потом как вы написали, потом как тут - https://doc.qt.io/qt-5/qstring.html#initializing-a-string перебрать строку и заменить слэши на пробелы. Но это костыль?

                                Evgenii Legotckoi
                                • 18 июня 2020 г. 18:10

                                Сдаётся мне, что у вас кодировка файла исходных кодов корявая.
                                Другой причины уже быть не может, иначе вам не пришлось бы заменять слэши. Дело в том, что слэш экранирует в код на C++ кавычки, чтобы это скомпилировалось нормально в строку.

                                  А как ее сменить?

                                    РС
                                    • 18 июня 2020 г. 20:15
                                    • Ответ был помечен как решение.

                                    Пересоздал таблицу в базе - все заработало без кавычек и public. Большое спасибо!

                                      Комментарии

                                      Только авторизованные пользователи могут публиковать комментарии.
                                      Пожалуйста, авторизуйтесь или зарегистрируйтесь
                                      г
                                      • ги
                                      • 23 апреля 2024 г. 22:51

                                      C++ - Тест 005. Структуры и Классы

                                      • Результат:41баллов,
                                      • Очки рейтинга-8
                                      l
                                      • laei
                                      • 23 апреля 2024 г. 16:19

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

                                      • Результат:10баллов,
                                      • Очки рейтинга-10
                                      l
                                      • laei
                                      • 23 апреля 2024 г. 16:17

                                      C++ - Тест 003. Условия и циклы

                                      • Результат:50баллов,
                                      • Очки рейтинга-4
                                      Последние комментарии
                                      k
                                      kmssr9 февраля 2024 г. 2:43
                                      Qt Linux - Урок 001. Автозапуск Qt приложения под Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                                      АК
                                      Анатолий Кононенко5 февраля 2024 г. 9:50
                                      Qt WinAPI - Урок 007. Работаем с ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                                      EVA
                                      EVA25 декабря 2023 г. 18:30
                                      Boost - статическая линковка в CMake проекте под Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
                                      J
                                      JonnyJo25 декабря 2023 г. 16:38
                                      Boost - статическая линковка в CMake проекте под Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
                                      G
                                      Gvozdik19 декабря 2023 г. 5:01
                                      Qt/C++ - Урок 056. Подключение библиотеки Boost в Qt для компиляторов MinGW и MSVC Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
                                      Сейчас обсуждают на форуме
                                      G
                                      Gar22 апреля 2024 г. 12:46
                                      Clipboard Как скопировать окно целиком в clipb?
                                      DA
                                      Dr Gangil Academics20 апреля 2024 г. 14:45
                                      Unlock Your Aesthetic Potential: Explore MSC in Facial Aesthetics and Cosmetology in India Embark on a transformative journey with an msc in facial aesthetics and cosmetology in india . Delve into the intricate world of beauty and rejuvenation, guided by expert faculty and …
                                      a
                                      a_vlasov14 апреля 2024 г. 13:41
                                      Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
                                      Павел Дорофеев
                                      Павел Дорофеев14 апреля 2024 г. 9:35
                                      QTableWidget с 2 заголовками Вот тут есть кастомный QTableView с многорядностью проект поддерживается, обращайтесь
                                      f
                                      fastrex4 апреля 2024 г. 11:47
                                      Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…

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