Oracle读取Blob数据-通过hibernate
2011-08-05 11:12
746 查看
通过hibernate向Oracle存储字节类型的数据(如byte[]等),在定义实体对象的时候不能用"private byte[] content", 这样定义我试过,在存储数据的时候(session.save(user))是没有问题的,但是在读取Blob字段(Oracle中存储byte[]使用的是"BLOB"类型)时就会出现问题,读出来的东西就成了乱码.
使用hibernate读取Blob字段时,实体对象(对应的byte[]类型字段)应该这样定义:
对应的hibernate文件配置:
在hibernate.cfg.xml文件中一定要添加这句话
读取Blob数据方法:
关于输入输出流
读入流自然要有读入的源头,输出也要输出到某个地方,输出一般是先要输读入,这里连接输入和输出的是一个在内存中的字节数组buffer.这样从数据库中读到这个数组里,输出流在从这个数组中输出到特定的文件格式里。
使用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>
在hibernate.cfg.xml文件中一定要添加这句话
<!--这句一定要加上,否则会报错,因为Oracle JDBC不允许流操作以批量方式进行,因此要关闭--> <property name="hibernate.jdbc.batch_size">0</property>
读取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.这样从数据库中读到这个数组里,输出流在从这个数组中输出到特定的文件格式里。
相关文章推荐
- Oracle读取Blob数据-通过JDBC
- 通过OracleDataReader来读取BLOB类型的数据
- JAVA通过Hibernate将文件写入ORACLE数据的BLOB字段 代码示例
- Oracle读取Blob数据-通过JDBC
- 通过OracleDataReader来读取BLOB类型的数据 (转载)
- 使用JDBC和Hibernate在oracle中插入和读取Blob数据的图片的java程序
- 通过OracleDataReader来读取BLOB类型的数据
- 分块读取Blob字段数据(Oracle)
- JDBC+Hibernate将Blob数据写入Oracle
- Oracle如何通过Database Link复制远程数据库表的CLOB/BLOB字段数据到本地数据库?
- JDBC+Hibernate将Blob数据写入Oracle
- JDBC+Hibernate将Blob数据写入Oracle
- 将oracle中blob数据写入文件,再把文件读取插入数据库
- 通过JDBC向数据库中存储&读取Blob数据
- ASP (非.NET) 通过 oo4o 读取 oracle long raw 类型数据图片
- 【转】hibernate oracle blob数据类型的处理
- 通过hibernate操作oracle的clob类型数据.doc
- JDBC+Hibernate将Blob数据写入Oracle
- Oracle 写入和读取blob类型的数据(C#)
- struts2+Hibernate 读取oracle blob 字段中的图片