提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
提示:这里可以添加本文要记录的大概内容:
项目数据存储需要用到数据库,免费好用的首选SQLite。
提示:以下是本篇文章正文内容,下面案例可供参考
SQLite 是一个 C 语言库,它实现了轻量级的关系型数据库的功能。与其他数据库系统(如 MySQL、PostgreSQL 等)相比,SQLite 具有一些显著的特点:
由于这些特点,SQLite 成为了一个流行的嵌入式数据库解决方案,被广泛应用于各种应用程序中,如移动应用程序、桌面应用程序和网页开发。
SQLite 是一个轻量级的数据库系统,常用于嵌入式系统和桌面应用程序。为了可视化 SQLite 数据库,可以使用一些第三方工具。以下是一些流行的 SQLite 可视化工具:
这些工具各有特点,你可以根据自己的需求选择最适合你的工具。如果你正在寻找一个简单、轻量级的解决方案,SQLiteBrowser 或 SQLiteStudio 可能是一个不错的选择。如果你需要更高级的功能,如数据迁移或与其他数据库系统的集成,DBeaver 或 DBConvert 可能更适合你。
以下是一个完整的例子,展示如何使用 Qt 操作 SQLite 数据库:
#include
#include
#include
#include
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
// 创建数据库连接
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("example.db"); // 使用本地数据库文件
if (!db.open()) {
qDebug() << "Failed to open database";
return -1;
}
// 创建表
QSqlQuery query;
if (!query.exec("CREATE TABLE Person (Id INT PRIMARY KEY, Name TEXT)")) {
qDebug() << "Failed to create table";
return -1;
}
// 插入数据
query.prepare("INSERT INTO Person (Id, Name) VALUES (:id, :name)");
query.bindValue(":id", 1);
query.bindValue(":name", "Alice");
if (!query.exec()) {
qDebug() << "Failed to insert data";
return -1;
}
query.prepare("INSERT INTO Person (Id, Name) VALUES (:id, :name)");
query.bindValue(":id", 2);
query.bindValue(":name", "Bob");
if (!query.exec()) {
qDebug() << "Failed to insert data";
return -1;
}
// 查询数据
query.prepare("SELECT * FROM Person");
if (query.exec()) {
while (query.next()) {
int id = query.value(0).toInt();
QString name = query.value(1).toString();
qDebug() << "ID:" << id << "Name:" << name;
}
} else {
qDebug() << "Failed to query data";
return -1;
}
// 关闭数据库连接
db.close(); // 记得关闭数据库连接!
return a.exec();
}
Qt 提供了一个用于操作 SQLite 数据库的强大模块。以下是一个简单的 Qt 示例,展示如何使用 Qt 操作 SQLite 数据库。
#include
#include
#include
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
// 创建数据库连接
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName(":memory:"); // 使用内存数据库,数据在退出时会被删除
if (!db.open()) {
qDebug() << "Failed to open database";
return -1;
}
// 创建表
QSqlQuery query;
if (!query.exec("CREATE TABLE Person (Id INT PRIMARY KEY, Name TEXT)")) {
qDebug() << "Failed to create table";
return -1;
}
// 插入数据
query.prepare("INSERT INTO Person (Id, Name) VALUES (:id, :name)");
query.bindValue(":id", 1);
query.bindValue(":name", "Alice");
if (!query.exec()) {
qDebug() << "Failed to insert data";
return -1;
}
// 查询数据
query.prepare("SELECT * FROM Person");
if (query.exec()) {
while (query.next()) {
int id = query.value(0).toInt();
QString name = query.value(1).toString();
qDebug() << "ID:" << id << "Name:" << name;
}
} else {
qDebug() << "Failed to query data";
return -1;
}
db.close(); // 记得关闭数据库连接!
return a.exec();
}
这个例程展示了如何使用 Qt 的 QSqlDatabase
和 QSqlQuery
类来创建、打开、操作和查询 SQLite 数据库。确保在 Qt 项目文件(.pro
文件)中添加了 QT += sql
来包含必要的模块。
总结了Qt +SQLite 的基础知识和应用