qt数据库增删改查sql语句
时间: 2024-12-31 15:29:45 浏览: 8
### Qt SQL 数据库增删改查示例
#### 连接到SQL Server数据库并执行基本操作
为了在Qt中实现对SQL Server数据库的增删改查功能,需使用Qt的SQL模块。以下是具体方法:
通过`QSqlDatabase`类来建立与SQL Server的连接,并设置相应的参数如主机地址、端口、用户名和密码等[^1]。
```cpp
#include <QCoreApplication>
#include <QtSql/QSqlDatabase>
#include <QtSql/QSqlQuery>
#include <QDebug>
bool createConnection()
{
QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
db.setHostName("localhost"); // 设置服务器名称
db.setPort(1433); // 设置端口号,默认为1433
db.setDatabaseName("TestDB"); // 替换成自己的数据库名字
db.setUserName("sa"); // 用户名
db.setPassword("password"); // 密码
if (!db.open()) {
qDebug() << "Failed to connect to database";
return false;
}
qDebug() << "Connected!";
return true;
}
```
一旦建立了成功的连接,则可以通过`QSqlQuery`对象来进行各种类型的查询语句执行,包括但不限于插入新记录、删除现有条目、更新已有信息以及检索特定的数据项。
对于增加一条新的记录而言,可采用如下方式构建INSERT INTO语句并向其中传递必要的字段值;同样地,在移除某一行时则应指定WHERE条件以便精准定位目标行;而修改某些属性的时候除了要指明SET部分外还需给出匹配规则用于限定受影响范围;最后读取多条或多列的结果可通过SELECT FROM... WHERE子句完成筛选工作。
```cpp
// 插入数据
void insertData(const QString &name, int age)
{
QSqlQuery query;
query.prepare("INSERT INTO Persons (PersonID, Name, Age) VALUES (:id, :name, :age)");
query.bindValue(":id", getNextId()); // 自定义函数获取下一个可用ID
query.bindValue(":name", name);
query.bindValue(":name", age);
if(!query.exec())
qDebug() << "Insert failed:" << query.lastError();
}
// 删除数据
void deleteData(int id)
{
QSqlQuery query;
bool success = query.exec(QString("DELETE FROM Persons WHERE PersonID=%1").arg(id));
if (!success)
qDebug() << "Delete failed:" << query.lastError();
}
// 更新数据
void updateData(int id, const QString& newName)
{
QSqlQuery query;
bool success = query.exec(QString("UPDATE Persons SET Name='%1' WHERE PersonID=%2").arg(newName).arg(id));
if (!success)
qDebug() << "Update failed:" << query.lastError();
}
// 查询数据
void selectAll()
{
QSqlQuery query;
query.exec("SELECT * FROM Persons");
while(query.next()){
qDebug()<< "ID:"<<query.value(0).toString()<<"Name:"<<query.value(1).toString()<<"Age:"<<query.value(2).toInt();
}
}
```
上述代码片段展示了如何利用Qt框架下的SQL接口轻松地管理关系型数据库中的表格内容,无论是添加还是编辑亦或是浏览都变得异常简便高效。
阅读全文