Дмитрий
Дмитрий6 октября 2021 г. 6: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
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

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

5
МЛ
  • 6 октября 2021 г. 6:20

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

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

на

q1.addBindValue(dt1.toString(Qt::ISODate));
    Дмитрий
    • 6 октября 2021 г. 6:38

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

      Дмитрий
      • 6 октября 2021 г. 7:11
      • Ответ был помечен как решение.

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

      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 октября 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 октября 2021 г. 11:56

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

            Комментарии

            Только авторизованные пользователи могут публиковать комментарии.
            Пожалуйста, авторизуйтесь или зарегистрируйтесь
            г
            • ги
            • 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…

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