Hibernate将文件二进制存入mysql

二进制大型对象(BLOB)列是MySQL的秘密武器之一。这些列中存储了二进制的数据,你可以象其它普通的数据类型一样来检索和操纵它。根据MySQL指南有关资料,BLOB是一个二进制大型对象,它能容纳不同大小的数据。事实上,MySQL有四种BLOB类型:

◆tinyblob:仅255个字符
◆blob:最大限制到65K字节
◆mediumblob:限制到16M字节
◆longblob:可达4GB


Java代码
  1. String fname = "c:\\itanger.gif";//要入库的文件    
  2. File f = new File(fname);    
  3. FileInputStream fin = new FileInputStream(f);    
  4. tad.setImage(Hibernate.createBlob(fin));   
String fname = "c:\\itanger.gif";//要入库的文件 
File f = new File(fname); 
FileInputStream fin = new FileInputStream(f); 
tad.setImage(Hibernate.createBlob(fin)); 


Java代码
  1. public void doGet(HttpServletRequest request,HttpServletResponse response){   
  2.         User user=(User)session.load(User.classnew Integer(1));   
  3.         Blob photo=user.getPhoto();   
  4.         InputStream in=photo.getBinaryStream();   
  5.         OutputStream out=response.getOutputStream();   
  6.         byte [] buf=new byte[1024];   
  7.         int len;   
  8.         while((len=in.read(buf))!=-1){   
  9.             out.write(buf, 0, len);   
  10.         }   
  11.         in.close();   
  12.         out.close();   
  13.     }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值