Дмитрий
Дмитрий06 жовтня 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
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

5
МЛ
  • 06 жовтня 2021 р. 06:20

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

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

на

q1.addBindValue(dt1.toString(Qt::ISODate));
    Дмитрий
    • 06 жовтня 2021 р. 06:38

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

      Дмитрий
      • 06 жовтня 2021 р. 07: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

            Коментарі

            Only authorized users can post comments.
            Please, Log in or Sign up
            m
            • molni99
            • 26 жовтня 2024 р. 08:37

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

            • Результат:80бали,
            • Рейтинг балів4
            m
            • molni99
            • 26 жовтня 2024 р. 08:29

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

            • Результат:20бали,
            • Рейтинг балів-10

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

            • Результат:42бали,
            • Рейтинг балів-8
            Останні коментарі
            A
            ALO1ZE19 жовтня 2024 р. 15:19
            Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
            ИМ
            Игорь Максимов05 жовтня 2024 р. 14:51
            Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
            d
            dblas505 липня 2024 р. 18:02
            QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
            k
            kmssr09 лютого 2024 р. 02:43
            Qt Linux - Урок 001. Автозапуск програми Qt під Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
            АК
            Анатолий Кононенко05 лютого 2024 р. 09:50
            Qt WinAPI - Урок 007. Робота з ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
            Тепер обговоріть на форумі
            jd
            jasmine disouza28 жовтня 2024 р. 11:58
            GeForce Now India: Unlocking the Future of Cloud Gaming GeForce Now India has a major impact on the gaming scene by introducing NVIDIA's cloud gaming service to Indian gamers. GeForce Now India lets you stream top-notch PC games on any device, from b…
            9
            9Anonim25 жовтня 2024 р. 16:10
            Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
            J
            JacobFib17 жовтня 2024 р. 10:27
            добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
            ИМ
            Игорь Максимов03 жовтня 2024 р. 11:05
            Реализация навигации по разделам Спасибо Евгений!
            JW
            Jhon Wick01 жовтня 2024 р. 22: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…

            Слідкуйте за нами в соціальних мережах