- 浏览: 7258771 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (1546)
- 企业中间件 (236)
- 企业应用面临的问题 (236)
- 小布Oracle学习笔记汇总 (36)
- Spring 开发应用 (54)
- IBatis开发应用 (16)
- Oracle基础学习 (23)
- struts2.0 (41)
- JVM&ClassLoader&GC (16)
- JQuery的开发应用 (17)
- WebService的开发应用 (21)
- Java&Socket (44)
- 开源组件的应用 (254)
- 常用Javascript的开发应用 (28)
- J2EE开发技术指南 (163)
- EJB3开发应用 (11)
- GIS&Mobile&MAP (36)
- SWT-GEF-RCP (52)
- 算法&数据结构 (6)
- Apache开源组件研究 (62)
- Hibernate 学习应用 (57)
- java并发编程 (59)
- MySQL&Mongodb&MS/SQL (15)
- Oracle数据库实验室 (55)
- 搜索引擎的开发应用 (34)
- 软件工程师笔试经典 (14)
- 其他杂项 (10)
- AndroidPn& MQTT&C2DM&推技术 (29)
- ActiveMQ学习和研究 (38)
- Google技术应用开发和API分析 (11)
- flex的学习总结 (59)
- 项目中一点总结 (20)
- java疑惑 java面向对象编程 (28)
- Android 开发学习 (133)
- linux和UNIX的总结 (37)
- Titanium学习总结 (20)
- JQueryMobile学习总结 (34)
- Phonegap学习总结 (32)
- HTML5学习总结 (41)
- JeeCMS研究和理解分析 (9)
最新评论
-
lgh1992314:
[u][i][b][flash=200,200][url][i ...
看看mybatis 源代码 -
尼古拉斯.fwp:
图片根本就不出来好吧。。。。。。
Android文件图片上传的详细讲解(一)HTTP multipart/form-data 上传报文格式实现手机端上传 -
ln94223:
第一个应该用排它网关吧 怎么是并行网关, 并行网关是所有exe ...
工作流Activiti的学习总结(八)Activiti自动执行的应用 -
ZY199266:
获取不到任何消息信息,请问这是什么原因呢?
ActiveMQ 通过JMX监控Connection,Queue,Topic的信息 -
xiaoyao霄:
DestinationSourceMonitor 报错 应该导 ...
ActiveMQ 通过JMX监控Connection,Queue,Topic的信息
使用Oracle来存储长文本始终没Mysql来的方便,Mysql不用特殊配置直接使用java.lang.String来存储Text 字段内容即可。这里可以看出Mysql的优势了吧。^-^
很久之前在网上找了些,加上自己摸索的,应该算是很简单的了。
来个总结备案。
步骤:
1。使用Clob类型来存储长文本。
2。在你的Spring的applicationContext-hibernate.xml里配置以下两个bean.
<bean id="nativeJdbcExtractor" class="org.springframework.jdbc.support.nativejdbc.SimpleNativeJdbcExtractor"/>
<bean id="oracleLobHandle" class="org.springframework.jdbc.support.lob.OracleLobHandler" Lazy-init="true">
<property name="nativeJdbcExtractor">
<ref local="nativeJdbcExtractor"/>
</property>
</bean>
3。在有clob类型sessionFactory(org.springframework.com.hibernate.LocalSessionFractoryBean)中加入
<property name="lobHandler"><ref bean="oracleLobHandle"/></property>
4。在*.hbm文件里使用长文本的字段加上对应的Java类型。
<property name="content" type="org.springframework.orm.hibernate3.support.ClobStringType" column="TRACK_CONTENT" length="100000"/>
5。上边的这个content,即JavaBean的对应的属性类型为String,不是ClobStringType。
如果只配置到这里的话,启动应用的时候会报缺少事务支持的错误,忘了具体报什么错了。
6。所以要给save,remove方法加上事务支持。
<bean id="txProxyTemplate" abstract="true"
class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="transactionManager"><ref bean="transactionManager"/></property>
<property name="transactionAttributes">
<props>
<prop key="save*">PROPAGATION_REQUIRED</prop>
<prop key="remove*">PROPAGATION_REQUIRED</prop>
<prop key="*">PROPAGATION_REQUIRED,readOnly</prop>
</props>
</property>
</bean>
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory"><ref bean="sessionFactory"/></property>
</bean>
<bean id="cnProjectTrackManager" parent="txProxyTemplate">
<property name="target">
<bean class="com.helloworld.cn.manager.project.bl.impl.ProjectTrackManagerImpl">
<property name="projectTrackDAO"><ref bean="cnProjectTrackDAO"/></property>
</bean>
</property>
</bean>
7。结束。
下边是配置所需的3个文件。
applicationContext.xml
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
"http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
<bean id="txProxyTemplate" abstract="true"
class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="transactionManager"><ref bean="transactionManager"/></property>
<property name="transactionAttributes">
<props>
<prop key="save*">PROPAGATION_REQUIRED</prop>
<prop key="remove*">PROPAGATION_REQUIRED</prop>
<prop key="*">PROPAGATION_REQUIRED,readOnly</prop>
</props>
</property>
</bean>
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory"><ref bean="sessionFactory"/></property>
</bean>
<bean id="cnProjectTrackManager" parent="txProxyTemplate">
<property name="target">
<bean class="com.helloworld.cn.manager.project.bl.impl.ProjectTrackManagerImpl">
<property name="projectTrackDAO"><ref bean="cnProjectTrackDAO"/></property>
</bean>
</property>
</bean>
<!-- bean id="jtaTransactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">
<property name="sessionFactory"><ref bean="sessionFactory"/></property>
</bean-->
<!--bean id="cnProjectTrackManager" class="com.helloworld.cn.manager.project.bl.impl.ProjectTrackManagerImpl">
<property name="projectTrackDAO"><ref bean="cnProjectTrackDAO"/></property>
</bean-->
</beans>
applicationContext-hibernate.xml
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
"http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
<!-- bean id="sessionFactory" class="org.springframework.orm.hibernate.LocalSessionFactoryBean" -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource"><ref bean="dataSource"/></property>
<property name="mappingResources">
<list>
<value>/hbm.ProjectTrack.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<!-- prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop-->
<prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop >
<!-- prop key="hibernate.dialect">net.sf.hibernate.dialect.MySQLDialect</prop -->
<!-- prop key="hibernate.hbm2ddl.auto">update</prop -->
<prop key="hibernate.show_sql">true</prop>
<!-- prop key="hibernate.jdbc.batch_size">0</prop-->
<prop key="hibernate.use_outer_join">true</prop>
<!-- prop key="hibernate.query.factory_class">org.hibernate.hql.classic.ClassicQueryTranslatorFactory</prop -->
</props>
</property>
<property name="lobHandler"><ref bean="oracleLobHandle"/></property>
</bean>
<bean id="oracleLobHandle" class="org.springframework.jdbc.support.lob.OracleLobHandler" lazy-init="true">
<property name="nativeJdbcExtractor">
<ref local="nativeJdbcExtractor"/>
</property>
</bean>
<bean id="nativeJdbcExtractor" class="org.springframework.jdbc.support.nativejdbc.SimpleNativeJdbcExtractor"/>
<bean id="cnProjectTrackDAO" class="com.helloworld.cn.manager.project.dao.hibernate.ProjectTrackDAOHibernate">
<property name="sessionFactory"><ref bean="sessionFactory"/></property>
</bean>
</beans>
hbm.ProjectTrack.xml
<!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.vitamin.cn.manager.project.entity.ProjectTrack" dynamic-update="false"
dynamic-insert="false" table="VITAMIN_CN_PROJECT_TRACK" lazy="false">
<id name="id" column="TRACK_ID" type="java.lang.Long" unsaved-value="null">
<!-- generator for mysql
<generator class="native">
</generator>
-->
<!-- generator for oracle -->
<generator class="sequence">
<param name="sequence">SEQ_CN_PROJECT_TRACK</param>
</generator>
</id>
<many-to-one name="project" column="PROJECT_ID"/>
<property name="date" type="java.util.Date" column="TRACK_DATE" />
<property name="editor" type="java.lang.String" column="TRACK_EDITOR" />
<property name="content" type="org.springframework.orm.hibernate3.support.ClobStringType" column="TRACK_CONTENT" length="100000"/>
<property name="name" type="java.lang.String" column="TRACK_NAME" />
</class>
</hibernate-mapping>
发表评论
-
【转】在项目中使用多个数据源-多sessionFactory方案
2013-05-10 16:30 3073适用范围:适合SSH架构访问多个数据库, ... -
【转】使用spring的动态路由实现数据库负载均衡
2013-03-17 22:57 3257使用spring的动态路由实现数据库负载均衡 系统中 ... -
【转】spring 数据库读写分离
2013-03-17 22:56 2760什么是数据库的读写分离 数据库的读写分离简单的说是把对数据 ... -
[转]Spring+iBatis+JOTM实现JTA事务
2013-03-17 22:51 3000Spring+iBatis+JOTM实现JTA事务 ... -
Spring 和Axis2整合相关那些事
2012-12-29 12:58 10362Axis2优劣: 现在用axis2开发一个webse ... -
【转】JAVA并发容器代码随读
2012-12-06 15:29 2913转载自 http://rdc.taobao.c ... -
Spring3.04和Junit4
2011-11-27 18:15 4327在Spring3.x以上必须采用 ... -
Spring加载属性文件的扩展
2011-08-22 12:21 2987在项目中一个属性文件配置信息,提供给数据连接信息 ... -
Brap和Spring整合(简单权限验证)
2011-07-26 10:31 1346在使用Spring的发 ... -
Quartz的任务的临时启动和暂停和恢复
2011-07-16 10:18 40013在项目中需要手动启停某些服务,那么需要有一个控 ... -
Quartz中定时调度EJB3.0服务
2011-07-13 22:25 2892在quartz2.0中只支持EJb2.0的服务 ... -
Quartz中定时调度EJB2.0服务
2011-07-13 22:12 2145在Quartz2.0中提供支持EJB2.0 ... -
Quartz的简单使用
2011-07-13 22:05 9897最近工作需要学习quartz,那么必须首先了解三个概念:调度器 ... -
Brap 远程访问调用 和Spring整合(二)
2010-12-08 14:52 1970Brap和 Spring 整合使用如 ... -
闲着没事Hessian开发WebService的总结(二)
2010-12-07 20:30 3990在Spring和Hessian整合中,以前 ... -
Spring JMX的学习总结(三) 基于注释的JMX的使用
2010-12-03 17:26 3324具体实现JMX的注释的类: package c ... -
Spring JMX的总结学习(二) 注解实现MBean
2010-12-03 17:24 6233本文采用Spring JMX ... -
Spring JMX的总结学习(一)基于标准接口的JMX
2010-12-03 17:21 3738在Spring中采用JMX标准形式的,开发相关的Spr ... -
Spring JMS的开发应用--自定义消息转换器的使用(四)
2010-12-03 01:37 2471在Spring JMS、中可以通过实现Me ... -
Spring JBOSSMQ JMS的开发应用(三)
2010-11-30 20:11 2310如果用过JMS的话,会发现它类似写JD ...
相关推荐
车辆管理系统(struts+hibernate+spring+oracle).rar
JSP源码——车辆管理系统(struts+hibernate+spring+oracle).zip
计算机毕业设计成品 JAVA JSP 车辆管理系统(struts+hibernate+spring+oracle) 计算机毕业设计成品 JAVA JSP 车辆管理系统(struts+hibernate+spring+oracle) 计算机毕业设计成品 JAVA JSP 车辆管理系统(struts+...
车辆管理系统基于struts+hibernate+spring+oracle 进行开发,主要实现车辆管理,车辆租赁,车辆定位等功能
车辆管理系统(struts+hibernate+spring+oracle)130225
车辆管理系统(struts+hibernate+spring+oracle)130225.rar,ssh的框架,数据库可以自动生成。
spring3+hibernate3+springMVC集成开发框架。
(1)该项目是基于spring3+struts2+hibernate3+spring security3的权限管理项目 (2)后台我已经实现了权限管理,包括用户,角色和资源的分配。前台实现了spring security3的管理 (3)网上案例普遍是后台单一登陆。...
本系统采用struts2+spring+hibernate+oracle代码齐全完整,适合作为SSH毕业设计,java毕业设计项目,计算机毕业设计,java课程设计,还是很不错的 很值得收藏 学习 探讨 研究。
基于Struts、Hibernate、Spring和Oracle技术的车辆管理系统,以其稳定可靠、高效灵活的特性,为各类企事业单位提供了强大的车辆管理解决方案。 Struts作为MVC框架的代表,为车辆管理系统提供了清晰的业务逻辑与页面...
hibernate中处理大字段 网上收集的文档
struts2、hibernate3、spring、ajax、oracle
struts2+hibernate3+spring3 例子(完整项目带 数据库文件) 可以直接运行 由于上传空间限制,部分jar地址http://download.csdn.net/source/2299572
struts+hibernate3+spring2+oracle10g的研究人员查询系统
以上是springmvc+spring+hibernate整合基于eclipse,oracle开发
spring3 hibernate3 整合
基于struts+spring+hibernate+oracle的移动ssh项目源码 基于struts+spring+hibernate+oracle的移动ssh项目源码 基于struts+spring+hibernate+oracle的移动ssh项目源码 基于struts+spring+hibernate+oracle的移动ssh...