加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

qt mysql blob存入图片、文本

(2016-06-16 16:28:13)
标签:

it

对于图片的存取其实很简单,但是在读取的时候需要用到QPixmap类的loadFromData对图片进行加载,第二个参数需要指定图片的格式,“jpg"/"png"如果对应不正确的话,图片就加载不出来,因此,最好在数据库中增加一个字段存储数据类型
1.图片的存入:
//插入图片
    QByteArray data;
    QFile* file=new QFile("D:\\test.jpg"); //fileName为二进制数据文件名
    file->open(QIODevice::ReadOnly);
    data = file->readAll();
    file->close();
    QVariant var(data);
    query.bindValue(":picture" , var);

2.图片的读取

QPixmap photo;

        photo.loadFromData(query.value(3).toByteArray(), query.value(4).toString().toLatin1());
//用label将图片进行加载

        ui->label->setPixmap(photo);

3.ini的与图片存入类似

4.ini的读取,PS:这里需要注意要设置让写入的代码支持中文,不然中文就会乱码或者显示问号

QFile file("D:\\test.ini");

        file.open(QIODevice::ReadWrite | QIODevice::Truncate);

        file.resize(0);

        QTextStream in(&file);



        QByteArray array = query.value(3).toByteArray();

        QTextCodec* gbk_codec = QTextCodec::codecForName("GBK");

        QString gbk_string = gbk_codec->toUnicode(array);

        in << gbk_string;


0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有