以下是一个简单的示例代码,可以将图片保存到 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`,分别用于存储图片的文件名和二进制数据。