Дмитрий
Дмитрий6. Oktober 2021 06:07

Вставка даты и времени в таблицу СУБД SQLite

qt, sql, sqlite, datetime, insert

Всем привет!

Использую базу данных SQLITE.
Пытаюсь в таблицу записать дату и время.
Делаю так:

QString q("CREATE TABLE IF NOT EXISTS dates (date1 DATETIME NOT NULL , date2 DATETIME NOT NULL)");
QSqlQuery query(db);
if(!query.exec(q))
{
        qDebug() << "Unable to create table meter_configurations";
}

QString qr("INSERT INTO dates (date1, date2 VALUES (?,?)");
QSqlQuery q1(db);
q1.prepare(qr);
QDateTime dt1 = QDateTime::currentDateTime();
QDateTime dt2 = QDateTime::currentDateTime();
q1.addBindValue(dt1);
q1.addBindValue(dt2);
if(!q1.exec())
{
    qDebug() << "Insert error!";
    qDebug() << q1.lastError();
    qDebug() << q1.lastQuery();
}

Но получаю ошибку: QSqlError("", "Parameter count mismatch", "")

Пробовал так:

QString qr("INSERT INTO dates (date1, date2 VALUES (datetime(?), datetime(?)");
QSqlQuery q1(db);
q1.prepare(qr);
QDateTime dt1 = QDateTime::currentDateTime();
QDateTime dt2 = QDateTime::currentDateTime();
q1.addBindValue(dt1.toString("yyyy-MM-dd hh:mm:ss"));
q1.addBindValue(dt2.toString("yyyy-MM-dd hh:mm:ss"));

Но получаю ту же ошибку.

Как вставить дату и время? Спасибо!

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

5

а если заменить

q1.addBindValue(dt1.toString("yyyy-MM-dd hh:mm:ss"));

на

q1.addBindValue(dt1.toString(Qt::ISODate));

    Попробовал - тоже самое

      Дмитрий
      • 6. Oktober 2021 07:11
      • Die Antwort wurde als Lösung markiert.

      Проблема решилась.
      Во вставке забыл одну закрывающую скобку в запросе. Нужно так:

      QString qr("INSERT INTO dates (date1, date2) VALUES (?,?)");
      QSqlQuery q1(db);
      q1.prepare(qr);
      QDateTime dt1 = QDateTime::currentDateTime();
      QDateTime dt2 = QDateTime::currentDateTime();
      q1.addBindValue(dt1);
      q1.addBindValue(dt2);
      
      if(!q1.exec())
      {
          qDebug() << "Insert error!";
          qDebug() << q1.lastError();
          qDebug() << q1.lastQuery();
      }
      
        ma
        • 26. Oktober 2021 11:55
        auto list_it_end = list.end();
                while (it != list_it_end)
                {
                    auto [asset, data, time, mks_time, price, operation, quality] = *it;
                    query.prepare( "INSERT INTO " + asset + "_ticker_table (asset, data, time, mks_time, price, operation, quality)" +
                        " VALUES(:asset, :data, :time, :mks_time, :price, :operation, :quality);");
        
                    query.bindValue(":asset", asset);
                    query.bindValue(":data", data);
                    query.bindValue(":time", time);
                    query.bindValue(":mks_time", mks_time);
                    query.bindValue(":price", price);
                    query.bindValue(":operation", operation);
                    query.bindValue(":quality", quality);
        
                    if (!query.exec())
                    {
                        Message mes(VIEW, VIEW_MESSAGE, NONE, ERROR_);
                        mes.add("ERROR DATABASE", query.lastError().text());
                        Send_Message(VIEW, mes);
                    }
                    ++it;
                    //str_insert.clear();
                    //insert.clear();
                }
        
          ma
          • 26. Oktober 2021 11:56

          Правда у меня Postgresql

            Kommentare

            Nur autorisierte Benutzer können Kommentare posten.
            Bitte Anmelden oder Registrieren
            Letzte Kommentare
            ИМ
            Игорь Максимов5. Oktober 2024 07:51
            Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
            d
            dblas55. Juli 2024 11:02
            QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
            k
            kmssr8. Februar 2024 18:43
            Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
            Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
            EVA
            EVA25. Dezember 2023 10:30
            Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
            Jetzt im Forum diskutieren
            J
            JacobFib17. Oktober 2024 03:27
            добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
            JW
            Jhon Wick1. Oktober 2024 15:52
            Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
            КГ
            Кирилл Гусарев27. September 2024 09:09
            Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
            F
            Fynjy22. Juli 2024 04:15
            при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

            Folgen Sie uns in sozialen Netzwerken