Russian Qt Forum
Ноябрь 23, 2024, 04:30 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
 
  Начало   Форум  WIKI (Вики)FAQ Помощь Поиск Войти Регистрация  

Страниц: [1]   Вниз
  Печать  
Автор Тема: [РЕШЕНО] Variant в PostgreSQL  (Прочитано 6947 раз)
sergek
Гипер активный житель
*****
Offline Offline

Сообщений: 872


Мы должны приносить пользу людям.


Просмотр профиля
« : Апрель 09, 2015, 13:22 »

Коллеги, мне нужно в таблицу записать, а потом прочитать значение переменной типа QVariant.
Как это можно сделать? Пока вижу 2 варианта: создать таблицу с несколькими полями ожидаемых типов, либо использовать строковое (а может bytea) поле, куда записывать сериализованный через QDataStream QVariant.
Может, с этим кто-нибудь уже сталкивался и решение совсем простое?
« Последнее редактирование: Апрель 10, 2015, 09:05 от sergek » Записан

Qt 5.13.0 Qt Creator 5.0.1
Win10, Ubuntu 20.04
PimenS
Крякер
****
Offline Offline

Сообщений: 371


Просмотр профиля
« Ответ #1 : Апрель 09, 2015, 14:03 »

Можно и записывать и читать через QSqlQuery.
Записан
sergek
Гипер активный житель
*****
Offline Offline

Сообщений: 872


Мы должны приносить пользу людям.


Просмотр профиля
« Ответ #2 : Апрель 09, 2015, 15:58 »

Можно и записывать и читать через QSqlQuery.
Улыбающийся

UPD. Не, строковое представление, наверное, не пойдет - с кодировками будут проблемы.
« Последнее редактирование: Апрель 09, 2015, 16:21 от sergek » Записан

Qt 5.13.0 Qt Creator 5.0.1
Win10, Ubuntu 20.04
PimenS
Крякер
****
Offline Offline

Сообщений: 371


Просмотр профиля
« Ответ #3 : Апрель 09, 2015, 19:28 »

Почему может быть проблема с кодировками? Использую сервера PostgreSQL на win и debian, на клиентских стоят win xp, win 7, win 8, ubuntu 12.04/14.04.
Ни разу проблем с кодировкой не возникло, ни при записи QVariant::String в varchar или text, ни при считывании.
Есть вариант, что с при записи timestamp возникнут разногласия (не ковырял, но мне хватает QDateTime::toString).
Еще при записи QUuid в uuid могут возникать проблемы при записи как QVariant::Uuid, тоже легко решается через QUuid::toString.
Записан
sergek
Гипер активный житель
*****
Offline Offline

Сообщений: 872


Мы должны приносить пользу людям.


Просмотр профиля
« Ответ #4 : Апрель 09, 2015, 22:06 »

Примерно так:
Код:
    CREATE TABLE variant
    (
      id serial NOT NULL,
      variant bytea
    );

Код:
    QVariant var = QDateTime::currentDateTime();
//    QVariant var = 1234567;
//    QVariant var = 1234.5678;
//    QVariant var = true;
    QByteArray arr;
    QDataStream out(&arr,QIODevice::WriteOnly);
    out << var;

    textEdit->append(QString("in = %1").arg(var.toString()));

    QSqlQuery query(db);
    query.prepare("INSERT INTO variant(variant) VALUES (:variant)");
    query.bindValue(":variant", arr);
    query.exec();
    int id = query.lastInsertId().toInt();

    // -------------

    query.prepare("select * from variant where id = :id");
    query.bindValue(":id", id);
    query.exec();

    query.next();
    QSqlRecord rec = query.record();

    QByteArray arr2 = query.value(rec.indexOf("variant")).toByteArray();
    QDataStream in(&arr2,QIODevice::ReadOnly);
    QVariant var2 = QVariant(in);

    textEdit->append(QString("out = %1").arg(var2.toString()));
Записан

Qt 5.13.0 Qt Creator 5.0.1
Win10, Ubuntu 20.04
PimenS
Крякер
****
Offline Offline

Сообщений: 371


Просмотр профиля
« Ответ #5 : Апрель 09, 2015, 23:28 »

Не понял к чему этот пример.

Для чего вот это?

Код:
    QVariant var = QDateTime::currentDateTime();
//    QVariant var = 1234567;
//    QVariant var = 1234.5678;
//    QVariant var = true;
    QByteArray arr;
    QDataStream out(&arr,QIODevice::WriteOnly);
    out << var;

Зачем вообще в данном примере QByteArray и QDataStream? Зачем в базе хранить строковый тип в двоичном виде? У PostgreSQL для строковых данных вполне хватает типов.
Почему нельзя сделать просто так:

Код:

    textEdit->append(QString("in = %1").arg(QDateTime::currentDateTime().toString()));

    QSqlQuery query(db);
    query.prepare("INSERT INTO variant(variant) VALUES (?)");
    query.addBindValue(textEdit);
    query.exec();

Записан
gil9red
Administrator
Джедай : наставник для всех
*****
Offline Offline

Сообщений: 1805



Просмотр профиля WWW
« Ответ #6 : Апрель 09, 2015, 23:51 »

Код:

    textEdit->append(QString("in = %1").arg(QDateTime::currentDateTime().toString()));

    QSqlQuery query(db);
    query.prepare("INSERT INTO variant(variant) VALUES (?)");
    query.addBindValue(textEdit);
    query.exec();

textEdit это же не QTextEdit, а QString?
Записан

PimenS
Крякер
****
Offline Offline

Сообщений: 371


Просмотр профиля
« Ответ #7 : Апрель 10, 2015, 00:00 »

Код:

    textEdit->append(QString("in = %1").arg(QDateTime::currentDateTime().toString()));

    QSqlQuery query(db);
    query.prepare("INSERT INTO variant(variant) VALUES (?)");
    query.addBindValue(textEdit);
    query.exec();

textEdit это же не QTextEdit, а QString?

Из примера непонятно, что это. Если это QTextEdit, то разница не велика query.addBindValue(textEdit->toPlainText()); ну или toHtml()
Записан
sergek
Гипер активный житель
*****
Offline Offline

Сообщений: 872


Мы должны приносить пользу людям.


Просмотр профиля
« Ответ #8 : Апрель 10, 2015, 09:04 »

textEdit это QTextEdit. Это неудачный пример (судя по реакции), который отображает строковое представление переменной QVariant.
В БД мне не нужно хранить строку, а переменную типа QVariant. В ней может быть что угодно - дата, целое, изображение. Нужно записать эту переменную в таблицу, а потом прочитать и опять вернуть в переменную QVariant, с сохранением типа данных.
Ну, раз нет больше ответов, кроме вопросов, тему закрываю.
Записан

Qt 5.13.0 Qt Creator 5.0.1
Win10, Ubuntu 20.04
Страниц: [1]   Вверх
  Печать  
 
Перейти в:  


Страница сгенерирована за 0.051 секунд. Запросов: 22.