C++ QT 将图片保存到SqlServer数据库

    以下是一个简单的示例代码,可以将图片保存到 SQL Server 数据库中:

     
    #include
    #include
    #include

    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,sqlserver,数据库,c++,上传图片)