使用Spring解决CLOB字段的存取
使用Spring解决CLOB字段的存取,记录一下,以备后用zzzzzzz...
首先使用网络上提供较多的解决办法,如下配置
<prop key="hibernate.connection.SetBigStringTryClob">true</prop><property name="context" type="text" column="context" />private String context;//getter & setter 然后直接save BO :报错Caused by: java.sql.SQLException: 不允许的操作: streams type cannot be used in batchingat oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:134)at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:179)at oracle.jdbc.driver.OraclePreparedStatement.addBatch(OraclePreparedStatement.java:4073)at org.apache.tomcat.dbcp.dbcp.DelegatingPreparedStatement.addBatch(DelegatingPreparedStatement.java:172)at org.hibernate.jdbc.BatchingBatcher.addToBatch(BatchingBatcher.java:53)at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2275)... 67 more
writeLog() ,调用者要声明事物,没必要把writeLog放到一个独立事物里(PROPAGATION_REQUIRES_NEW)或放到嵌套事物里;saveXXX(){ --<prop key="save*">PROPAGATION_REQUIRED</prop>即可//businesswriteLog();}<!-- Spring-hibernate.xml --><bean id="nativeJdbcExtractor" /><bean id="lobHandler" /> </property></bean> <bean id="sessionFactory" /><!-- BO.java-->private String context; //getter & setter 然后就可以使用Hibernate保存BO:OK//Spring 处理CLOB,未配置事物Caused by: java.lang.IllegalStateException: Active Spring transaction synchronization or active JTA transaction with specified [javax.transaction.TransactionManager] requiredat org.springframework.jdbc.support.lob.LobCreatorUtils.registerTransactionSynchronization(LobCreatorUtils.java:79)at org.springframework.orm.hibernate3.support.AbstractLobType.nullSafeSet(AbstractLobType.java:185)at org.hibernate.type.CustomType.nullSafeSet(CustomType.java:169)