Hibernate第四天
来源:互联网 发布:linux iptables pdf 编辑:程序博客网 时间:2024/06/05 15:46
Lazy:延迟加载。
Hibrnater:类型是去掉路径,首字母小写。比如
注意的是Hibrnater的date日期和java的不一样 timestamp
小练习
一对一关联
首先PO类
再者POhbm.xml
当然还要配置hibernate.cfg.xml
持久类:
PS:
如何将oracle中存放的图片(如Blob类类型的字段)还原成一副图片
在Oracle中,LOB(Large Object,大型对象)类型的字段现在用得越来越多了。因为这种类型的字段,容量大(最多能容纳4GB的数据),且一个表中可以有多个这种类型的字段,很灵活,适用于数据量非常大的业务领域(如图象、档案等)。而LONG、LONG RAW等类型的字段,虽然存储容量也不小(可达2GB),但由于一个表中只能有一个这样类型的字段的限制,现在已很少使用了。
LOB类型分为BLOB和CLOB两种:BLOB即二进制大型对象(Binary Large Object),适用于存贮非文本的字节流数据(如程序、图象、影音等)。而CLOB,即字符型大型对象(Character Large Object),则与字符集相关,适于存贮文本型的数据(如历史档案、大部头著作等)。
下面以程序实例说明通过JDBC操纵Oracle数据库LOB类型字段的几种情况。
二是插入方式不同。
LOB数据不能象其它类型数据一样直接插入(INSERT)。插入前必须先插入一个空的LOB对象,CLOB类型的空对象为EMPTY_CLOB(),BLOB类型的空对象为EMPTY_BLOB()。之后通过SELECT命令查询得到先前插入的记录并锁定,继而将空对象修改为所要插入的LOB对象。
三是修改方式不同。
其它类型的字段修改时,用UPDATE … SET…命令即可。而LOB类型字段,则只能用SELECT … FOR UPDATE命令将记录查询出来并锁定,然后才能修改。且修改也有两种改法:一是在原数据基础上的修改(即覆盖式修改),执行SELECT … FOR UPDATE后再改数据;二是替换(先将原数据清掉,再修改),先执行UPDATE命令将LOB字段之值设为空的LOB对象,然后进行第一种改法。建议使用替换的方法,以实现与其它字段UPDATE操作后一样的效果。
四是存取时应使用由数据库JDBC驱动程序提供的LOB操作类。
对于Oracle数据库,应使用oracle.sql.CLOB和oracle.sql.BLOB。不使用由数据库JDBC驱动程序提供的LOB类时,程序运行时易于出现“抽象方法调用”的错误,这是因为JDBC所定义的java.sql.Clob与java.sql.Blob接口,其中的一些方法并未在数据库厂家提供的驱动程序中真正实现。
五是存取手段与文件操作相仿。
对于BLOB类型,应用InputStream/OutputStream类,此类不进行编码转换,逐个字节存取。oracle.sql.BLOB类相应提供了getBinaryStream()和getBinaryOutputStream()两个方法,前一个方法用于读取Oracle的BLOB字段,后一个方法用于将数据写入Oracle的BLOB字段。
对于CLOB类型,应用Reader/Writer类,此类进行编码转换。oracle.sql.CLOB类相应提供了getCharacterStream()和getCharacterOutputStream()两个方法,前一个方法用于读取Oracle的CLOB字段,后一个方法用于将数据写入Oracle的CLOB字段。
需要说明的是,为了大幅提高程序执行效率,对BLOB/CLOB字段的读写操作,应该使用缓冲操作类(带Buffered前缀),即:BufferedInputStream,BufferedOutputStream,BufferedReader,BufferedWriter。例程中全部使用了缓冲操作类。
- hibernate第四天
- Hibernate第四天
- Hibernate第四天
- Hibernate框架第四天
- Hibernate学习第四天
- Hibernate第四天
- ## Hibernate框架的第四天 ##
- Hibernate框架基础知识第四天查询
- hibernate学习笔记第四天(1)
- hibernate学习笔记第四天(2)
- hibernate学习笔记第四天(3)
- Hibernate学习笔记(第四天)
- 笔记·Hibernate框架第四天
- Hibernate第四阶段
- hibernate 学习笔记(马士兵教程) 第四天
- hibernate的映射和延迟加载--第四天
- Hibernate框架的第四天(查询方式和策略)
- Hibernate 学习笔记第四篇
- 无法埋葬的青春
- XP下安装openssl的过程
- 关于socket阻塞与非阻塞情况下的recv、send、read、write返回值
- gg
- ManualResetEvent Class
- Hibernate第四天
- 我对数据库范式的理解
- WCF通信协议
- socket详解
- label标题过长时显示...
- 使用Java等比例缩放图像
- 谢谢你,给了我忘记的理由
- phpbb 3 源码解析02 --common.php
- 皱建老师的SQL全角/半角转换