使用hibnate向数据库写入图片对象

写入到数据库:

@Test
    public void testwriteBlob() throws Exception{
        Students s = new Students(1,"张三","男",new Date(),"河南");
        //获取照片
        File f = new File("/Users/liqiye/Desktop/banner1.jpg");
        //获得输入流
        InputStream input = new FileInputStream(f);
        //创建Blob对象
        Blob image = Hibernate.getLobCreator(session).createBlob(input, input.available());
        //设置照片属性
        s.setPicture(image);
        session.save(s);
        
    }

 

从数据库读取出来:

@Test
    public void testReadBlob() throws Exception{
        Students s = (Students)session.get(Students.class, 1);
        Blob b = s.getPicture();
        //获得输入流
        InputStream input = b.getBinaryStream();
        
        File f = new File("/Users/liqiye/Desktop/dest.jpg");
        //获得输出流
        OutputStream out = new FileOutputStream(f);
        //创建缓存区
        byte[] buffer = new byte[input.available()];
        //将输入流读到缓冲区里
        input.read(buffer);
        //从缓冲区写出到文件
        out.write(buffer);
        input.close();
        out.close();
        
    }

转载于:https://www.cnblogs.com/liqy/p/7990024.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值