hibernate中映射blob数据类型的一个例子

J ava 代码
  1. publicclass User  implements java.io.Serializable {   
  2.   
  3.   
  4.     // Fields      
  5.   
  6.      privatelong id;   
  7.      private String name;   
  8.      private String email;   
  9.      private String addr;   
  10.      //定义Blob的pthto  
  11.      private Blob photo;  
xml 代码
  1. <hibernate-mapping>  
  2.     <classname="org.tie.User"table="user"catalog="tie">  
  3.         <idname="id"type="long">  
  4.             <columnname="id"/>  
  5.             <generatorclass="identity"/>  
  6.         </id>  
  7.         <propertyname="name"type="string">  
  8.             <columnname="name"length="45"not-null="true"/>  
  9.         </property>  
  10.         <propertyname="email"type="string">  
  11.             <columnname="email"length="45"/>  
  12.         </property>  
  13.         <propertyname="addr"type="string">  
  14.             <columnname="addr"length="45"/>  
  15.         </property>  
  16.         <!-- 映射blob类型 -->  
  17.         <propertyname="photo"type="blob">  
  18.             <columnname="photo"/>  
  19.         </property>  
  20.     </class>  
  21. </hibernate-mapping>  

两个测试方法:

java 代码
  1. publicvoid testCreate(){   
  2.            
  3.          User user = new User();   
  4.          user.setName("linweiyang");   
  5.          user.setAddr("beijing");   
  6.          user.setEmail("linweiyang@163.com");   
  7.          Blob photo = null;   
  8.        
  9.         try {   
  10.             //将图片读进输入流  
  11.              FileInputStream fis =new FileInputStream("c:\\a.jpg");   
  12.             //转成Blob类型  
  13.              photo = Hibernate.createBlob(fis);   
  14.                
  15.          } catch (FileNotFoundException e) {   
  16.              e.printStackTrace();   
  17.          } catch (IOException e) {   
  18.              e.printStackTrace();   
  19.          }   
  20.                
  21.          user.setPhoto(photo);   
  22.            
  23.          Session session = factory.openSession();   
  24.          Transaction tr = session.beginTransaction();   
  25.          session.save(user);   
  26.          tr.commit();   
  27.          session.close();   
  28.   
  29.      }   
  30.        
  31.     publicvoid testRerieve(){   
  32.            
  33.          Session session = factory.openSession();   
  34.          User user = (User)session.load(User.class,new Long(3));   
  35.         try {   
  36.             //从数据库中要读取出来  
  37.              InputStream is = user.getPhoto().getBinaryStream();   
  38.             //在把写到一个图片格式的文件里  
  39.              FileOutputStream fos =new FileOutputStream("c:\\linweihan.jpg");   
  40.                
  41.             byte[] buffer =new byte[1024];   
  42.             int len =0;   
  43.             //从数据库中读取到指定的字节数组中  
  44.             while((len = is.read(buffer) )!= -1){   
  45.                 //从指定的数组中读取,然后输出来,所以这里buffer好象是连接inputStream和outputStream的一个东西  
  46.                  fos.write(buffer,0,len);   
  47.              }   
  48.          } catch (FileNotFoundException e) {   
  49.              e.printStackTrace();   
  50.          } catch (SQLException e) {   
  51.              e.printStackTrace();   
  52.          } catch (IOException   e){   
  53.              e.printStackTrace();   
  54.          }              
  55.          session.close();   
  56.      }  

这么理解输入输出流

读入流,自然要有读入的源头,

输出也要输出到某个地方,输出一般是先要输读入,

这里连接输入和输出的是一个在内存中的字节数组buffer.这样从数据库中读到这个数组里,输出流在从这个数组中输出到特定的文件格式里.

来源:http://hi.baidu.com/networkcrazy/blog/item/1398b155f0ef1350d0090602.html


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值