java Hibernate 处理 oracle xmltype类型
网上关于如何处理oracle xmltype类型的博客很多,我现在分享的是针对具体业务来的,我在oracle数据库entity表中detail插入了一条xmltype类型的数据
xml的详细内容如下:
<Family>
<Person>
<name>Jack</name>
<phone>123</phone>
<address>
<company>常州</company>
<home>常州</home>
</address>
</Person>
<Person>
<name>Tom</name>
<phone>456</phone>
<address>
<company>无锡</company>
<home>无锡</home>
</address>
</Person>
<Person>
<name>Andy</name>
<phone>789</phone>
<address>
<company>苏州</company>
<home>苏州</home>
</address>
</Person>
</Family>
现在要实现的业务是在前端表格中显示相应数据

我想到了3种解决途径,后来花费了一天功夫,才解决了这个业务需求。
方案一、采用oracle通过Hibernate在java中映射的实体才操作
oracle xmltype类型继承clob大数据类型,通过Hibernate操作在java中映射的实体类型为string类型,再通过dao层去存取该实体。
这个时候就遇到问题了,将xml编辑为string类型后entity.setDetail(xml);sava(entity);数据中数据被更新了,没有问题,但是entity,getDetail()的时候获得的数据为null但是数据库却是有数据的。
在花费了一段时间之后,发现需要自己编写一个类去替换string,最后取出的类型是docoment类型,将document类型做处理就好了,以下附上相关的一些资料:
1、使用Hibernate4处理Oracle XmlType字段类型
2、解决:Weblogic容器、SSH框架下Hibernate映射Oracle XMLType方法与Jar包冲突
方案二、采用Hibernate连接写sql获取xmltype的值
String sql = "select en.detail as de from entity en where en.id = '123'";
List<Map<String,Object>> list = jdbcTemplate.queryForList(sql);
结果发现报错,javax.persistence.PersistenceException: org.hibernate.MappingException: No Dialect mapping for JDBC type: 2009
查资料没发现有效的解决方案,舍弃
方案三、使用oracle自带的处理xmltype的函数进行数据读取
Oracle 中XML处理函数介绍,附上函数资料,但是发现这样子取数据必须知道数据条数而且取很麻烦
在查询资料以后发现,对与获取相同标签下的数据的时候可以使用xmltable函数,附上sql语句:
select en.id, x.*
from entity en,xmltable('/Family/Person' passing en.detail columns name path 'name',
phone path 'phone') x
where ed.id = '123'
需要注意的问题是,使用这种方法的时候,如果节点下还有子节点,那么会报方案二的错误,暂时没有找到解决方案,要处理这种情况还是选择方案一吧。
暂时就想到这几种解决方案。
java Hibernate 处理 oracle xmltype类型的更多相关文章
- Hibernate写入Oracle Date类型处理
Hibernate写入Oracle数据库时,数据库设计字段为Date类型时,只能保存年月日,不能保存时分秒,如果要保存时分秒,需修改Hibernate.cfg.xml文件 <property n ...
- java plsql 调用oracle数组类型
首先当然是在oracle中建立type CREATE OR REPLACE TYPE cux_proxy_bid_award_rec IS OBJECT ( trading_partner_id NU ...
- hibernate中java类的成员变量类型如何映射到SQL中的数据类型变化
hibernate映射文件??.hbm.xml配置映射元素详解--Hibernate映射类型 在从Hibernate的java的成员类型映射到SQL中的数据类型,其内映射方式它满足,SQL可以自己调制 ...
- java 实现往oracle存储过程中传递array数组类型的参数
注:本文来源于 < java 实现往oracle存储过程中传递array数组类型的参数 >最近项目中遇到通过往存储过程传递数组参数的问题, 浪费了N多个小时,终于有点头绪. 具体的代码 ...
- oracle xmltype导入并解析Excel数据--前言
通常,很多的时候,我们需要导入Excel数据到系统中,但是Excel数据需要我们去各种校验,比如身份证校验,手机号码校验等等. 校验失败的数据,提供Excel导出错误原因,提示给用户. 如此,如果校验 ...
- oracle xmltype导入并解析Excel数据 (三)解析Excel数据
包声明 create or replace package PKG_EXCEL_UTILS is -- Author: zkongbai-- Create at: 2016-07-06-- Actio ...
- oracle ORA-01747(系统保留关键字)user.table.column, table.column 或列说明无效 hibernate映射oracle保留关键字
1.查询系统关键 select * from v$reserved_words 确认你使用的是否为关键字: select * from v$reserved_words w where w.KEYWO ...
- oracle字段类型
oracle 字段类型CHAR 固定长度字符串 最大长度2000 bytes VARCHAR2 可变长度的字符串 最大长度4000 byt ...
- Hibernate遇到oracle之主键生成策略
一直用Hibernate+mysql,感觉Hibernate很好用,也出过什么大问题:这周,公司的产品要部署到Orecle,虽然产品号称支持Oracle但是我自己知道,这个产品压根儿就没在Oracle ...
随机推荐
- Beego 框架学习(一)
Beego官网本身已经整理的非常详细了,但是作为一个学习者,我还是决定自己好好整理一下,这样在后面使用的时候自己对每部分才能非常熟悉,及时忘记了,也可以迅速定位自己要用的知识在哪里.当然也是对官网的一 ...
- JDBC控制事务
概念 事务(Transaction)是访问并可能更新数据库中各种数据项的一个程序执行单元(unit).事务通常由高级数据库操纵语言或编程语言(如SQL,C++或Java)书写的用户程序的执行所引起,并 ...
- Swift 笔记汇总
Swift 3 笔记 Swift: The Basics :介绍 Swift 一些零碎的点. Swift: Basic Operators :介绍 Swift 的操作符. Functions : 介绍 ...
- Elasticsearch就这么简单
一.前言 最近有点想弄一个站内搜索的功能,之前学过了Lucene,后来又听过Solr这个名词.接着在了解全文搜索的时候就发现了Elasticsearch这个,他也是以Lucene为基础的. 我去搜了几 ...
- [POJ 3635] Full Tank?
题目 Description 已知每个点的加油站的油价单价(即点权),每条路的长度(边权). 有q个询问,每个询问包括起点s.终点e和油箱容量c. 问从起点走到终点的最小花费.如果不可达输出impos ...
- DOM节点的创建
1.createAttribute() 创建一个属性节点 => 接收参数为string类型的属性名称 var a=document.getElementsByClassName('name1') ...
- java大数(BigInteger)
JAVA之BigInteger 用Java来处理高精度问题,相信对很多ACMer来说都是一件很happy的事,简单易懂.用Java刷了一些题,感觉Java还不错,在处理高精度和进制转换中,调用库函数的 ...
- 选择排序—简单选择排序(Simple Selection Sort)
基本思想: 在要排序的一组数中,选出最小(或者最大)的一个数与第1个位置的数交换:然后在剩下的数当中再找最小(或者最大)的与第2个位置的数交换,依次类推,直到第n-1个元素(倒数第二个数)和第n个元素 ...
- Jmeter 后置处理器 BeanShell_PostProcessor 适用思考
首先摘抄一段官方文档的话: The following BeanShell variables are set up for use by the script: log - (Logger) - c ...
- 论文阅读——Visual inertial odometry using coupled nonlinear optimization
简介:论文提出一种新的视觉里程计算法,其直接利用带噪声的IMU数据和视觉特征位置来优化相机位姿.不同于对IMU和视觉数据运行分离的滤波器,这种算法将它们纳入联合的非线性优化框架中.视觉特征的透视重投影 ...