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 ...
随机推荐
- Cloudera Manager及CDH最新版本安装全程记录
大家都知道,Apache Hadoop的配置很繁琐,而且很零散,为此Cloudera公司提供了Clouder Manager工具,而且还封装了Apache Hadoop,flume,spark,hiv ...
- es6学习笔记--新数据类型Symbol
学习了es6语法的symbol类型,整理笔记,闲时复习. Symbol 是es6新增的第七种原始数据类型(null,string,number,undefined,boolean,object),是为 ...
- c++趣味之难以发现的bug
这些bug可能够你喝一壶的. 1.被断言(assert)包含的代码 常发生在切换到release版本时,执行结果乖乖的,最终查找结果是assert括号里的代码在release下是不执行的. 发现:跟踪 ...
- Vue自定义插件方法大全
新年第一天首先祝大家新年快乐,心想事成! 1.利用根实例构造函数的原型 //在构造函数的原型链上添加自定义属性 Vue.prototype.test = 'pomelo' //在其他组件中调用 con ...
- 笔记:Jersey REST 传输格式-JSON
JSON 类型已经成为Ajax技术中数据传输的实际标准,Jersey 提供了多种处理JSON数据的包和解析方式,下表展示了JSON包和解析方式: 解析方式\JSON支持包 MOXy JSON-P Ja ...
- flex布局之兼容
Android 2.3 开始就支持旧版本 display:-webkit-box; 4.4 开始支持标准版本 display: flex; IOS 6.1 开始支持旧版本 display:-webk ...
- 手把手 git建立仓库,远程推拉及常用git命令和部分Linux命令集锦
方法一:直接在GitHub上建立一个项目,然后git clone (git address name): 此时已经建立好了一个git仓库: cd 文件夹 > 添加文件进去 >git add ...
- opencv配置
1.安装opecv库 从官网http://opencv.org/下载OpenCV windows版 运行之后 2.配置环境变量 64位系统,可以将32位和64位两个都添加上,免得以后编译不同程序再来配 ...
- windows+CMake+mingw 搭建c c++开发环境
layout: post title: "windows+CMake+mingw 搭建c c++开发环境" date: 2018-03-30 22:23:06 tags: wind ...
- 假设检验(Hypothesis Testing)
假设检验(Hypothesis Testing) 1. 什么是假设检验呢? 假设检验又称为统计假设检验,是数理统计中根据一定假设条件由样本推断总体的一种方法. 什么意思呢,举个生活中的例子:买橘子(借 ...