QT+C++环境使用SQLite数据库的基本功能介绍--增删查改

使用sqlite自带的数据库,chinook.db,对数据库进行连接、打开、读取、添加、查询、更改、删除等操作.

 

#include "mainwindow.h"
#include <QApplication>
#include <QSqlDatabase>
#include <QSqlError>
#include <QSqlQuery>
#include<QDebug>
#include <QtSql/QSqlRecord>

typedef struct _MediaTypeInfo //假定数据库存储内容
{
	QString MediaTypeId;
	QString Name;

}MediaTypeInfo;

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    MainWindow w;
    w.show();

    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    db.setDatabaseName("c:\\sqlite\\db\\chinook.db");  //读取本地数据库的
    bool ok = db.open();

    if (ok)
    {
        qDebug() << "db opened.";
    }

	QSqlQuery query;

	query.prepare("SELECT * FROM media_types");
	query.exec();
	QSqlReco
要在Qt和VS环境中连接SQLite数据库,您需要按照以下步骤进行操作: 1. 首先,确保您已经安装了Qt和Visual Studio,并且已经正确配置了它们。 2. 下载SQLite的预编译二进制文件。您可以从SQLite的官方网站(https://www.sqlite.org/download.html)下载预编译二进制文件。选择与您的操作系统和框架(32位或64位)匹配的版本。 3. 在Qt项目中创建一个新的C++类(例如,命名为DatabaseManager),用于管理数据库连接和操作。 4. 将SQLite的预编译二进制文件添加到您的Qt项目中。将SQLite的头文件和库文件复制到您的项目文件夹中,并在Qt项目文件(.pro文件)中添加以下行: ``` INCLUDEPATH += path_to_sqlite_headers LIBS += -Lpath_to_sqlite_libs -lsqlite ``` 将"path_to_sqlite_headers"和"path_to_sqlite_libs"替换为实际路径。 5. 在DatabaseManager类中,使用以下代码连接到SQLite数据库: ```cpp #include <QSqlDatabase> #include <QSqlQuery> // ... QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); db.setDatabaseName("path_to_your_database_file"); if (!db.open()) { // 处理数据库连接失败的情况 } else { // 数据库连接成功,可以执行查询和操作 } ``` 将"path_to_your_database_file"替换为您的SQLite数据库文件的路径。 6. 在连接成功后,您可以使用QSqlQuery类执行SQL查询和操作。例如: ```cpp QSqlQuery query; query.prepare("SELECT * FROM your_table"); if (query.exec()) { while (query.next()) { // 处理查询结果 } } else { // 处理查询执行失败的情况 } ``` 您可以根据需要修改查询语句和处理结果的逻辑。 这样,您就可以在Qt和VS环境中连接和使用SQLite数据库了。记得根据您的具体情况修改代码中的路径和查询语句。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值