使用Spring的JdbcTemplate处理Clob

2024-06-06 11:18

本文主要是介绍使用Spring的JdbcTemplate处理Clob,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 数据库表 req_seq

 

CREATE TABLE req_seq
(
req_id VARCHAR2(36) PRIMARY KEY,
seq VARCHAR2(100),
req_xml CLOB,
req_time DATE
);

 

2. 实体类

 

import java.io.Serializable;
import java.sql.Timestamp;
import java.text.SimpleDateFormat;public class ReqSeqBean implements Serializable {/*** @Fields serialVersionUID : TODO*/private static final long serialVersionUID = -4200518336372141644L;// 主键private String reqId;// 请求序列private String req;// 请求XMLprivate String reqXml;// 请求时间private Timestamp reqTime;public String toString() {SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");StringBuffer buf = new StringBuffer("ReqSeqBean:[");buf.append("reqId=").append(reqId).append(", ");buf.append("req=").append(req).append(", ");buf.append("reqXml=").append(reqXml).append(", ");buf.append("reqTime=").append(df.format(reqTime));return buf.toString();}// 省略 setter/getter
}

 

 

注意: 数据库表中,REQ_XML 的类型是 CLOB,实体类中是 String

 

3. DAO层配置

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans><bean id="nativeJdbcExtractor" class="org.springframework.jdbc.support.nativejdbc.CommonsDbcpNativeJdbcExtractor"lazy-init="true"/><bean id="oracleLobHandler" class="org.springframework.jdbc.support.lob.OracleLobHandler" lazy-init="true"><property name="nativeJdbcExtractor" ref="nativeJdbcExtractor"/></bean><bean id="reqSeqDAO" class="com.dao.ReqSeqDAO"><property name="jdbcTemplate" ref="jdbcTemplate" /><property name="hisJdbcTemplate" ref="jdbcTemplate" /><property name="lobHandler" ref="oracleLobHandler"/></bean>
</beans>

 

4. DAO

import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.core.support.AbstractLobCreatingPreparedStatementCallback;
import org.springframework.jdbc.support.lob.LobCreator;
import org.springframework.jdbc.support.lob.LobHandler;public class ReqSeqDAO extends BaseDao {private static final Logger log = LoggerFactory.getLogger(ReqSeqDAO.class);private LobHandler lobHandler;/*** @Title: addReqSeq* @deprecated: 如果字段REQ_XML是clob类型,则用此方法,但是需要oracle版本和jdk版本一致* @param bean* @throws Exception* @author * @date 2013年10月23日*/public void addReqSeq(final ReqSeqBean bean) throws Exception {StringBuffer sql = new StringBuffer();sql.append("INSERT INTO REQ_SEQ(REQ_ID, SEQ, REQ_XML, REQ_TIME) ");sql.append("VALUES(SYS_GUID(), ?, ?, ");sql.append("TO_DATE(TO_CHAR(SYSDATE,'yyyy-MM-dd hh24:mi:ss'),'yyyy-MM-dd hh24:mi:ss'))");getJdbcTemplate().execute(sql.toString(),new AbstractLobCreatingPreparedStatementCallback(lobHandler) {@Overrideprotected void setValues(PreparedStatement ps,LobCreator lobCreator) throws SQLException,DataAccessException {ps.setString(1, bean.getReq());lobCreator.setClobAsString(ps, 2, bean.getReqXml());}});}/*** @Title: queryReqSeqList* @deprecated: 按条件查找请求序列信息(如果字段REQ_XML是clob类型,则用此方法,但是需要oracle版本和jdk版本一致)* @param bean*            查询条件* @return List* @throws Exception* @author * @date 2013年10月23日*/public List<ReqSeqBean> queryReqSeqList(ReqSeqBean bean) throws Exception {StringBuffer sql = new StringBuffer("SELECT * FROM REQ_SEQ WHERE 1 = 1 ");// 查询条件List<String> params = new ArrayList<String>(1);if (null != bean) {/* 添加查询条件 */if (null != bean.getReq()) {// 请求序列号sql.append(" AND SEQ = ? ");params.add(bean.getReq());}}sql.append(" ORDER BY REQ_TIME DESC");final List<ReqSeqBean> list = new ArrayList<ReqSeqBean>(10);getJdbcTemplate().query(sql.toString(), params.toArray(),new RowMapper() {@Overridepublic Object mapRow(ResultSet rs, int rowNum)throws SQLException {ReqSeqBean seq = new ReqSeqBean();seq.setReqId(rs.getString("REQ_ID"));seq.setReq(rs.getString("SEQ"));seq.setReqXml(lobHandler.getClobAsString(rs,"REQ_XML"));seq.setReqTime(rs.getTimestamp("REQ_TIME"));list.add(seq);return seq;}});return list;}public LobHandler getLobHandler() {return lobHandler;}public void setLobHandler(LobHandler lobHandler) {this.lobHandler = lobHandler;}
}

 

 

这篇关于使用Spring的JdbcTemplate处理Clob的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1035960

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na