РС
Маусым 19, 2020, 2:01 Т.Ж.

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

qt, DataBase, QML

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

2

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

19
Evgenii Legotckoi
  • Маусым 19, 2020, 2:18 Т.Ж.

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

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

  1. query.prepare("INSERT INTO \"public\".\"NameTable\" (\"FirstName\", \"SurName\", \"Nik\") VALUES ('ff', 'cc', 'bb');")
    РС
    • Маусым 19, 2020, 2: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
      • Маусым 19, 2020, 2:41 Т.Ж.

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

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

        Evgenii Legotckoi
        • Маусым 19, 2020, 2:49 Т.Ж.
        • (өңделген)

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

          РС
          • Маусым 19, 2020, 2:50 Т.Ж.
          1. bool DataBase::inserIntoTable(const QVariantList &data)
          2. {
          3.  
          4. QSqlQuery query;
          5.  
          6. query.prepare("INSERT INTO \"public\".\"NameTable\" (\"FirstName\", \"SurName\", \"Nik\") VALUES ('ff', 'cc', 'bb');");
          7.  
          8. if(!query.exec()){
          9. qDebug() << "error insert into " << TABLE;
          10. qDebug() << query.lastQuery();
          11. qDebug() << query.lastError().text();
          12. return false;
          13. } else {
          14. return true;
          15. }
          16. return false;
          17. }
            Evgenii Legotckoi
            • Маусым 19, 2020, 2:54 Т.Ж.

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

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

            1. "INSERT INTO \"public\".\"NameTable\" ( \"FisrtName\", \"SurName\", \"Nik\") VALUES (:db, 'cc', \"bb\")"
              РС
              • Маусым 19, 2020, 2:55 Т.Ж.

              "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
                • Маусым 19, 2020, 3:02 Т.Ж.

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

                1. QSqlQuery query;
                2. query.prepare("INSERT INTO person (id, forename, surname) "
                3. "VALUES (:id, :forename, :surname)");
                4. query.bindValue(":id", 1001);
                5. query.bindValue(":forename", "Bart");
                6. query.bindValue(":surname", "Simpson");
                7. query.exec();

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

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

                1. bool DataBase::inserIntoTable(const QVariantList &data)
                2. {
                3.  
                4. QSqlQuery query;
                5.  
                6. query.prepare("INSERT INTO public.NameTable (FirstName, SurName, Nik) VALUES (:db, 'cc', 'bb');");
                7. query.bindValue(":db", data[0].toString());
                8.  
                9. if(!query.exec()){
                10. qDebug() << "error insert into " << TABLE;
                11. qDebug() << query.lastQuery();
                12. qDebug() << query.lastError().text();
                13. return false;
                14. } else {
                15. return true;
                16. }
                17. return false;
                18. }

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

                  РС
                  • Маусым 19, 2020, 3:07 Т.Ж.
                  1. error insert into NameTable
                  2. "INSERT INTO public.NameTable (FirstName, SurName, Nik) VALUES ('ffb', 'cc', 'bb');"
                  3. "ОШИБКА: ошибка синтаксиса в конце\nLINE 1: EXECUTE \n ^\n(42601) QPSQL: Невозможно создать запрос"
                    Evgenii Legotckoi
                    • Маусым 19, 2020, 3:20 Т.Ж.

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

                    1. bool DataBase::inserIntoTable(const QVariantList &data)
                    2. {
                    3.  
                    4. QSqlQuery query;
                    5.  
                    6. query.prepare("INSERT INTO NameTable (FirstName, SurName, Nik) VALUES (:FName, :SName, :Nik)");
                    7. query.bindValue(":FName", "Name");
                    8. query.bindValue(":SName", "Surname");
                    9. query.bindValue(":Nik", "Nik");
                    10.  
                    11. if(!query.exec()){
                    12. qDebug() << "error insert into " << TABLE;
                    13. qDebug() << query.lastQuery();
                    14. qDebug() << query.lastError().text();
                    15. return false;
                    16. } else {
                    17. return true;
                    18. }
                    19. return false;
                    20. }
                      РС
                      • Маусым 19, 2020, 3:22 Т.Ж.

                      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
                        • Маусым 19, 2020, 3:30 Т.Ж.

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

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

                          РС
                          • Маусым 19, 2020, 3:32 Т.Ж.

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

                            Evgenii Legotckoi
                            • Маусым 19, 2020, 3:38 Т.Ж.

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

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

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

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

                            1. INSERT INTO films (code, title, did, date_prod, kind)
                            2. VALUES ('T_601', 'Yojimbo', 106, '1961-06-16', 'Drama');
                              РС
                              • Маусым 19, 2020, 4:03 Т.Ж.

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

                                Evgenii Legotckoi
                                • Маусым 19, 2020, 4:10 Т.Ж.

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

                                  РС
                                  • Маусым 19, 2020, 4:44 Т.Ж.

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

                                    РС
                                    • Маусым 19, 2020, 6:15 Т.Ж.
                                    • Жауап шешім ретінде белгіленді.

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

                                      Пікірлер

                                      Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
                                      Кіріңіз немесе Тіркеліңіз