]
Dan Berindei updated ISPN-2082:
-------------------------------
Status: Resolved (was: Pull Request Sent)
Fix Version/s: 9.1.0.Final
9.0.4.Final
9.1.0.CR2
Resolution: Done
JdbcStringBasedCacheStore: ORA-24816 when storing BLOB values >
4000 bytes
--------------------------------------------------------------------------
Key: ISPN-2082
URL:
https://issues.jboss.org/browse/ISPN-2082
Project: Infinispan
Issue Type: Bug
Components: Loaders and Stores
Affects Versions: 5.1.5.FINAL
Environment: OS X 10.7.4, JDK 1.7.0u4
Reporter: Ryan Scharer
Assignee: Ryan Emerson
Fix For: 9.1.0.Final, 9.0.4.Final, 9.1.0.CR2
I've configured a JdbcStringBasedCacheStore with a VARCHAR(4000) key column and a
BLOB value column. If I try to store a BLOB value of less than 4000 bytes, everything
works fine. If the value is greater, the cache store fails with ORA-24816. This occurs
because the BLOB column is not the last one in the PreparedStatement SQL as the Oracle
driver requires. My current, sad workaround is to clone the JdbcStringBasedCacheStore
implementation and write my own insert/update SQL in storeLockSafe(). This works fine,
but obviously isn't ideal from an upgrade point of view. Simply overriding
storeLockSafe() isn't an option due to all the private fields.