在Qt中实现数据库的连接和查询,需要以下步骤:
- 引入相关头文件和命名空间
#include <QtSql>
using namespace std;
- 建立数据库连接
QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
db.setHostName("localhost"); // 数据库服务器IP地址或名称
db.setPort(3306); // 数据库端口号,默认为3306
db.setUserName("root"); // 登录数据库的用户名
db.setPassword("123456"); // 登录数据库的密码
db.setDatabaseName("test_db"); // 数据库名称
if (!db.open()) {
qDebug() << "无法建立数据库连接!";
return -1;
}
- 执行SQL查询语句
// 查询数据表中所有数据并输出到控制台
QSqlQuery query;
query.exec("SELECT * FROM students");
while (query.next()) {
QString name = query.value(0).toString();
int age = query.value(1).toInt();
QString gender = query.value(2).toString();
qDebug() << name << age << gender;
}
- 关闭数据库连接
db.close();
完整示例代码如下:
#include <QtSql>
#include <QDebug>
using namespace std;
int main(int argc, char *argv[])
{
QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
db.setHostName("localhost");
db.setPort(3306);
db.setUserName("root");
db.setPassword("123456");
db.setDatabaseName("test_db");
if (!db.open()) {
qDebug() << "无法建立数据库连接!";
return -1;
}
QSqlQuery query;
query.exec("SELECT * FROM students");
while (query.next()) {
QString name = query.value(0).toString();
int age = query.value(1).toInt();
QString gender = query.value(2).toString();
qDebug() << name << age << gender;
}
db.close();
return 0;
}
注意:在使用Qt操作数据库时,需要保证已经正确安装相应的数据库驱动程序(例如QMYSQL),并将其引入到项目中。同时,还需要根据具体情况修改数据库连接参数和SQL查询语句。