Последние записи
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
30th
Янв
SQLite сохранить базу в файл (C/C++ Базы данных)
Posted by obzor under c/c++
Как можно сохранить базу данных SQLite v3 в формат .sql для дальнейшей загрузки в такую же базу. Нужно для сохранения текущего состояния.
Поделюсь своим решением проблемы, может кому пригодится.
void MainWindow::on_SaveFile_triggered(){
ui->textEdit->clear();
QString fileName = QFileDialog::getSaveFileName(this,
tr("Сохранить файл"), "", tr("Игра (*.sql)"));
if (fileName != "") {
QFile file(fileName);
if (!file.open(QIODevice::WriteOnly)) {
QMessageBox msgBox; msgBox.setText("Не могу записать файл"); msgBox.exec();
//или как выше, коротко QMessageBox::critical...
}
else {
QSqlQuery query;
QDate cd = QDate::currentDate(); // возвращаем текущую дату
QTime ct = QTime::currentTime(); // возвращаем текущее время
QString data = cd.toString("dd MMMM yyyy");
QString time = ct.toString("hh:mm:ss");
if (!query.exec("SELECT * FROM good")){
qDebug() << "Error SELECT * FROM good";
}
QSqlRecord rec = query.record();
ui->textEdit->append(QString("--\n-- Файл сгенерирован с помощью SQLiteStudio v3.2.1 %1 в %2\n--\n-- Использованная кодировка текста: UTF-8\n--\nPRAGMA foreign_keys = off;\nBEGIN TRANSACTION;\n\n-- Таблица: good;").arg(data).arg(time));
while(query.next()){
QString num = query.value(rec.indexOf("number")).toString();
QString kod = query.value(rec.indexOf("kod")).toString();
ui->textEdit->append(QString("UPDATE good SET kod= " + kod + " WHERE number= "+num));
}
if (!query.exec("SELECT * FROM nogood")){
qDebug() << "Error SELECT * FROM nogood";
}
ui->textEdit->append(QString("\n-- Таблица: nogood;"));
while(query.next()){
QString num = query.value(rec.indexOf("number")).toString();
QString kod = query.value(rec.indexOf("kod")).toString();
ui->textEdit->append(QString("UPDATE nogood SET kod= " + kod + " WHERE number= "+num));
}
ui->textEdit->append(QString("\nCOMMIT TRANSACTION;\nPRAGMA foreign_keys = on;\n"));
QTextStream stream(&file);
stream << ui->textEdit->toPlainText();
stream.flush();
ui->textEdit->clear();
file.close();
}
}
}
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)