HHH-18480 ClassCastException when updating a Blob with Oracle
This commit is contained in:
parent
6cc292e9d3
commit
d8ad674e7f
|
@ -132,10 +132,7 @@ public class BlobJavaType extends AbstractClassJavaType<Blob> {
|
|||
}
|
||||
}
|
||||
else if ( Blob.class.isAssignableFrom( type ) ) {
|
||||
final Blob blob = value instanceof WrappedBlob
|
||||
? ( (WrappedBlob) value ).getWrappedBlob()
|
||||
: getOrCreateBlob(value, options);
|
||||
return (X) blob;
|
||||
return (X) getOrCreateBlob( value, options );
|
||||
}
|
||||
}
|
||||
catch ( SQLException e ) {
|
||||
|
@ -146,6 +143,9 @@ public class BlobJavaType extends AbstractClassJavaType<Blob> {
|
|||
}
|
||||
|
||||
private Blob getOrCreateBlob(Blob value, WrapperOptions options) throws SQLException {
|
||||
if ( value instanceof WrappedBlob ) {
|
||||
value = ( (WrappedBlob) value ).getWrappedBlob();
|
||||
}
|
||||
if ( options.getDialect().useConnectionToCreateLob() ) {
|
||||
if ( value.length() == 0 ) {
|
||||
// empty Blob
|
||||
|
|
|
@ -105,10 +105,7 @@ public class ClobJavaType extends AbstractClassJavaType<Clob> {
|
|||
}
|
||||
}
|
||||
else if ( Clob.class.isAssignableFrom( type ) ) {
|
||||
final Clob clob = value instanceof WrappedClob
|
||||
? ( (WrappedClob) value ).getWrappedClob()
|
||||
: getOrCreateClob(value, options);
|
||||
return (X) clob;
|
||||
return (X) getOrCreateClob( value, options );
|
||||
}
|
||||
else if ( String.class.isAssignableFrom( type ) ) {
|
||||
if (value instanceof ClobImplementer) {
|
||||
|
@ -129,6 +126,9 @@ public class ClobJavaType extends AbstractClassJavaType<Clob> {
|
|||
}
|
||||
|
||||
private Clob getOrCreateClob(Clob value, WrapperOptions options) throws SQLException {
|
||||
if ( value instanceof WrappedClob ) {
|
||||
value = ( (WrappedClob) value ).getWrappedClob();
|
||||
}
|
||||
if ( options.getDialect().useConnectionToCreateLob() ) {
|
||||
if ( value.length() == 0 ) {
|
||||
// empty Clob
|
||||
|
|
|
@ -104,10 +104,7 @@ public class NClobJavaType extends AbstractClassJavaType<NClob> {
|
|||
}
|
||||
}
|
||||
else if ( NClob.class.isAssignableFrom( type ) ) {
|
||||
final NClob nclob = value instanceof WrappedNClob
|
||||
? ( (WrappedNClob) value ).getWrappedNClob()
|
||||
: getOrCreateNClob(value, options);
|
||||
return (X) nclob;
|
||||
return (X) getOrCreateNClob( value, options );
|
||||
}
|
||||
}
|
||||
catch ( SQLException e ) {
|
||||
|
@ -118,6 +115,9 @@ public class NClobJavaType extends AbstractClassJavaType<NClob> {
|
|||
}
|
||||
|
||||
private NClob getOrCreateNClob(NClob value, WrapperOptions options) throws SQLException {
|
||||
if ( value instanceof WrappedNClob ) {
|
||||
value = ( (WrappedNClob) value ).getWrappedNClob();
|
||||
}
|
||||
if ( options.getDialect().useConnectionToCreateLob() ) {
|
||||
if ( value.length() == 0 ) {
|
||||
// empty NClob
|
||||
|
@ -132,7 +132,6 @@ public class NClobJavaType extends AbstractClassJavaType<NClob> {
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
public <X> NClob wrap(X value, WrapperOptions options) {
|
||||
if ( value == null ) {
|
||||
return null;
|
||||
|
|
Loading…
Reference in New Issue