以下是一个简单的示例代码,可以将图片保存到 SQL Server 数据库中:
#include <QtSql>
#include <QFile>
#include <QByteArray>
int main(int argc, char *argv[])
{
// 连接 SQL Server 数据库
QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
db.setDatabaseName("DRIVER={SQL Server};SERVER=localhost;DATABASE=mydb;UID=myuser;PWD=mypassword;");
if (!db.open()) {
qDebug() << "Failed to connect to database.";
return 1;
}
// 读取图片文件
QFile file("image.jpg");
if (!file.open(QIODevice::ReadOnly)) {
qDebug() << "Failed to open file.";
return 1;
}
QByteArray imageData = file.readAll();
file.close();
// 将图片数据保存到数据库中
QSqlQuery query(db);
query.prepare("INSERT INTO images (name, data) VALUES (:name, :data)");
query.bindValue(":name", "image.jpg");
query.bindValue(":data", imageData);
if (!query.exec()) {
qDebug() << "Failed to save image to database.";
return 1;
}
// 关闭数据库连接
db.close();
return 0;
}
这个示例假设已经在 SQL Server 数据库中创建了一个名为 `images` 的表,其中包含两个列:`name` 和 `data`,分别用于存储图片的文件名和二进制数据。
该示例展示如何使用Qt的QSql模块连接到SQLServer数据库,并将图片文件读取为二进制数据,然后将其存储到数据库的images表中。程序首先打开数据库连接,读取image.jpg文件,然后执行SQL插入语句,将文件名和二进制数据保存到images表的name和data列中。
11万+

被折叠的 条评论
为什么被折叠?



