Михаиллл
Михаиллл16 мая 2020 г. 13:11

Как в postgresql сохранить QByteArray

Добрый день.
Создал в postgresql столбец типа oid для хранения QByteArray.
Почитал что oid аналог BLOD, самого BLOB у меня в базе нет.
Но при таком типе данных не могу записать QByteArray, получаю такую ошибку:


При этом с oid работает только такой запрос (в этот тип данных записывается только число):

INSERT INTO public.categories(
    name, image)
    VALUES ( 'hh', 100);

Скажите пожалуйста как записывать QByteArray ? В какойто другой тип данных?

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

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

2
ИП
  • 17 мая 2020 г. 6:05
  • (ред.)

Нужно использовать подготовленный запрос https://doc.qt.io/qt-5/qsqlquery.html
вот пример из документации

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

addBindValue принимает тип QVariant, в него сохраняешь QByteArray и отправляешь в запрос

QByteArray ba;// QByteArray который нужно сохранить
...
Query query;
query.prepare("INSERT INTO public.categories(name, image) VALUES ( 'hh', ?);");
query.addBindValue(ba);
//Ну или можно явно указать компилятору что хочешь сделать
//query.addBindValue(QVariant(ba));
query.exec();

...
    Михаиллл
    • 17 мая 2020 г. 6:13
    • Ответ был помечен как решение.

    Я так и делал. Оказывается в постгри столбец нужно делать в формате bytea

      Комментарии

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

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

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

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

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

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

      • Результат:50баллов,
      • Очки рейтинга-4
      Последние комментарии
      k
      kmssr8 февраля 2024 г. 15:43
      Qt Linux - Урок 001. Автозапуск Qt приложения под Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
      АК
      Анатолий Кононенко4 февраля 2024 г. 22:50
      Qt WinAPI - Урок 007. Работаем с ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
      EVA
      EVA25 декабря 2023 г. 7:30
      Boost - статическая линковка в CMake проекте под Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
      J
      JonnyJo25 декабря 2023 г. 5:38
      Boost - статическая линковка в CMake проекте под Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
      G
      Gvozdik18 декабря 2023 г. 18:01
      Qt/C++ - Урок 056. Подключение библиотеки Boost в Qt для компиляторов MinGW и MSVC Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
      Сейчас обсуждают на форуме
      G
      Gar22 апреля 2024 г. 2:46
      Clipboard Как скопировать окно целиком в clipb?
      DA
      Dr Gangil Academics20 апреля 2024 г. 4: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 г. 3:41
      Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
      Павел Дорофеев
      Павел Дорофеев13 апреля 2024 г. 23:35
      QTableWidget с 2 заголовками Вот тут есть кастомный QTableView с многорядностью проект поддерживается, обращайтесь
      f
      fastrex4 апреля 2024 г. 1:47
      Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…

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