Oracle读取Blob数据-通过hibernate
通过hibernate向Oracle存储字节类型的数据(如byte[]等),在定义实体对象的时候不能用"private byte[] content", 这样定义我试过,在存储数据的时候(session.save(user))是没有问题的,但是在读取Blob字段(Oracle中存储byte[]使用的是"BLOB"类型)时就会出现问题,读出来的东西就成了乱码.
使用hibernate读取Blob字段时,实体对象(对应的byte[]类型字段)应该这样定义:
- import java.io.Serializable;
- import java.sql.Blob;
- public class User implements Serializable {
- // Fields
- private long id;
- private String name;
- private String email;
- private String addr;
- // 定义Blob的pthto
- private Blob photo;
- // getter and setters
- ......
- }
对应的hibernate文件配置:
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
- <Hibernate-mapping>
- <class name="com.xxx.xxx.User" table="user">
- <id name="id" type="java.lang.Long">
- <column name="id" />
- <generator class="increment" />
- </id>
- <property name="name" type="java.lang.String">
- <column name="name" length="45" not-null="true" />
- </property>
- <property name="email" type="java.lang.String">
- <column name="email" length="45" />
- </property>
- <property name="addr" type="java.lang.String">
- <column name="addr" length="45" />
- </property>
- <!-- 映射blob类型 -->
- <property name="photo" type="java.sql.Blob">
- <column name="photo" />
- </property>
- </class>
- </Hibernate-mapping>
读取Blob数据方法:
- // 写方法
- public void testCreate(){
- User user = new User();
- user.setName("linweiyang");
- user.setAddr("beijing");
- user.setEmail("linweiyang@163.com");
- Blob photo = null;
- try {
- //将图片读进输入流
- FileInputStream fis = new FileInputStream("c:\\a.jpg");
- //转成Blob类型
- photo = Hibernate.createBlob(fis);
- } catch (FileNotFoundException e) {
- e.printStackTrace();
- } catch (IOException e) {
- e.printStackTrace();
- }
- user.setPhoto(photo);
- Session session = factory.openSession();
- Transaction tr = session.beginTransaction();
- session.save(user);
- tr.commit();
- session.close();
- }
- // 读方法
- public void testRerieve(){
- Session session = factory.openSession();
- User user = (User)session.load(User.class, new Long(3));
- try {
- //从数据库中要读取出来
- InputStream is = user.getPhoto().getBinaryStream();
- //在把写到一个图片格式的文件里
- FileOutputStream fos = new FileOutputStream("c:\\linweihan.jpg");
- byte[] buffer = new byte[1024];
- int len = 0;
- //从数据库中读取到指定的字节数组中
- while((len = is.read(buffer) )!= -1){
- //从指定的数组中读取,然后输出来,所以这里buffer好象是连接inputStream和outputStream的一个东西
- fos.write(buffer,0,len);
- }
- } catch (FileNotFoundException e) {
- e.printStackTrace();
- } catch (SQLException e) {
- e.printStackTrace();
- } catch (IOException e) {
- e.printStackTrace();
- }
- session.close();
- }
关于输入输出流
读入流自然要有读入的源头,输出也要输出到某个地方,输出一般是先要输读入,这里连接输入和输出的是一个在内存中的字节数组buffer.这样从数据库中读到这个数组里,输出流在从这个数组中输出到特定的文件格式里
为人:谦逊、激情、博学、审问、慎思、明辨、 笃行
学问:纸上得来终觉浅,绝知此事要躬行
为事:工欲善其事,必先利其器。
态度:道阻且长,行则将至;行而不辍,未来可期
.....................................................................
------- 桃之夭夭,灼灼其华。之子于归,宜其室家。 ---------------
------- 桃之夭夭,有蕡其实。之子于归,宜其家室。 ---------------
------- 桃之夭夭,其叶蓁蓁。之子于归,宜其家人。 ---------------
=====================================================================
* 博客文章部分截图及内容来自于学习的书本及相应培训课程以及网络其他博客,仅做学习讨论之用,不做商业用途。
* 如有侵权,马上联系我,我立马删除对应链接。 * @author Alan -liu * @Email no008@foxmail.com
转载请标注出处! ✧*꧁一品堂.技术学习笔记꧂*✧. ---> https://www.cnblogs.com/ios9/
学问:纸上得来终觉浅,绝知此事要躬行
为事:工欲善其事,必先利其器。
态度:道阻且长,行则将至;行而不辍,未来可期
.....................................................................
------- 桃之夭夭,灼灼其华。之子于归,宜其室家。 ---------------
------- 桃之夭夭,有蕡其实。之子于归,宜其家室。 ---------------
------- 桃之夭夭,其叶蓁蓁。之子于归,宜其家人。 ---------------
=====================================================================
* 博客文章部分截图及内容来自于学习的书本及相应培训课程以及网络其他博客,仅做学习讨论之用,不做商业用途。
* 如有侵权,马上联系我,我立马删除对应链接。 * @author Alan -liu * @Email no008@foxmail.com
转载请标注出处! ✧*꧁一品堂.技术学习笔记꧂*✧. ---> https://www.cnblogs.com/ios9/