您好,登錄后才能下訂單哦!
在這個 C++ 實踐案例中,我們將使用 Qt 框架和 SQLite 數據庫創建一個簡單的記事本應用程序。這個應用程序將包含一個文本編輯器和一個用于保存和加載數據的數據庫。
首先,確保你已經安裝了 Qt 和 SQLite。接下來,我們將創建一個新的 Qt Widgets Application 項目并命名為 “NotepadApp”。
在項目的 .pro 文件中,添加以下內容:
QT += core gui sql
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
使用 Qt Designer,創建一個簡單的用戶界面,包括一個 QTextEdit(用于編輯文本)和兩個 QPushButton(用于保存和加載數據)。將這些控件連接到相應的槽函數。
在 mainwindow.cpp 文件中,包含以下頭文件:
#include <QSqlDatabase>
#include <QSqlQuery>
#include <QDebug>
然后,在 MainWindow 構造函數中,創建數據庫和表:
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent), ui(new Ui::MainWindow) {
ui->setupUi(this);
// 創建數據庫
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("notedata.db");
if (!db.open()) {
qDebug() << "Error: Failed to connect to database.";
} else {
qDebug() << "Connected to database.";
}
// 創建表
QSqlQuery query;
query.exec("CREATE TABLE IF NOT EXISTS notes (id INTEGER PRIMARY KEY AUTOINCREMENT, content TEXT)");
}
在 mainwindow.h 文件中,添加以下槽函數聲明:
private slots:
void on_saveButton_clicked();
void on_loadButton_clicked();
然后,在 mainwindow.cpp 文件中,實現這些槽函數:
void MainWindow::on_saveButton_clicked() {
QString content = ui->textEdit->toPlainText();
QSqlQuery query;
query.prepare("INSERT INTO notes (content) VALUES (:content)");
query.bindValue(":content", content);
query.exec();
qDebug() << "Note saved.";
}
void MainWindow::on_loadButton_clicked() {
QSqlQuery query;
query.exec("SELECT * FROM notes ORDER BY id DESC LIMIT 1");
if (query.next()) {
QString content = query.value("content").toString();
ui->textEdit->setPlainText(content);
} else {
qDebug() << "No note found.";
}
}
現在,你已經創建了一個簡單的記事本應用程序,它可以將文本保存到 SQLite 數據庫中,并從數據庫中加載文本。運行應用程序并測試其功能。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。