- All Implemented Interfaces:
- Serializable,- Binding<byte[],- byte[]> 
Blob to at the
 JDBC level.
 This is useful for workarounds for bugs in Oracle, like ORA-01461: can bind a LONG value only for insert into a LONG column (see [#4091])
- Author:
- Lukas Eder
- See Also:
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionfinal Converter<byte[],byte[]> A converter that can convert between the database type and the custom type.final voidget(BindingGetResultSetContext<byte[]> ctx) Get aResultSet'sOUTvalue.final voidget(BindingGetSQLInputContext<byte[]> ctx) Get aSQLInput'sOUTvalue.final voidget(BindingGetStatementContext<byte[]> ctx) Get aCallableStatement'sOUTvalue.final voidregister(BindingRegisterContext<byte[]> ctx) Register aCallableStatement'sOUTparameter.final voidset(BindingSetSQLOutputContext<byte[]> ctx) Set aSQLOutput'sINparameter.final voidset(BindingSetStatementContext<byte[]> ctx) Set aPreparedStatement'sINparameter.final voidsql(BindingSQLContext<byte[]> ctx) Generate SQL code for the bind variable.
- 
Constructor Details- 
BlobBindingpublic BlobBinding()
 
- 
- 
Method Details- 
converterDescription copied from interface:BindingA converter that can convert between the database type and the custom type.
- 
sqlDescription copied from interface:BindingGenerate SQL code for the bind variable.Implementations should generate SQL code onto BindingSQLContext.render(), given the context's bind variable located atBindingSQLContext.value(). Examples of such SQL code are:- "?": Default implementations can simply generate a question mark.
 
 
- "123": Implementations may choose to inline bind variables to influence execution plan generation.
 
 - Context.paramType()contains information whether inlined bind variables are expected in the current context.
 
 
- "CAST(? AS DATE)": Cast a database to a more specific type. This can be useful in databases like Oracle, which map both- DATEand- TIMESTAMPSQL types to- Timestamp.
 
 - Context.castMode()may contain some hints about whether casting is suggested in the current context.
 
 
- "?::json": Vendor-specific bind variables can be supported, e.g.- SQLDialect.POSTGRES's JSON data type.
 Implementations must provide consistent behaviour between Binding.sql(BindingSQLContext)andBinding.set(BindingSetStatementContext), i.e. when bind variables are inlined, then they must not be bound to thePreparedStatementinBinding.set(BindingSetStatementContext)- Specified by:
- sqlin interface- Binding<byte[],- byte[]> 
- Parameters:
- ctx- The context object containing all argument objects.
- Throws:
- SQLException- Implementations are allowed to pass on all- SQLExceptions to the caller to be wrapped in- DataAccessExceptions.
 
- 
registerDescription copied from interface:BindingRegister aCallableStatement'sOUTparameter.- Specified by:
- registerin interface- Binding<byte[],- byte[]> 
- Parameters:
- ctx- The context object containing all argument objects.
- Throws:
- SQLException- Implementations are allowed to pass on all- SQLExceptions to the caller to be wrapped in- DataAccessExceptions.
 
- 
setDescription copied from interface:BindingSet aPreparedStatement'sINparameter.- Specified by:
- setin interface- Binding<byte[],- byte[]> 
- Parameters:
- ctx- The context object containing all argument objects.
- Throws:
- SQLException- Implementations are allowed to pass on all- SQLExceptions to the caller to be wrapped in- DataAccessExceptions.
 
- 
setDescription copied from interface:BindingSet aSQLOutput'sINparameter.- Specified by:
- setin interface- Binding<byte[],- byte[]> 
- Parameters:
- ctx- The context object containing all argument objects.
- Throws:
- SQLException- Implementations are allowed to pass on all- SQLExceptions to the caller to be wrapped in- DataAccessExceptions.
 
- 
getDescription copied from interface:BindingGet aResultSet'sOUTvalue.Implementations are expected to produce a value by calling BindingGetResultSetContext.value(Object), passing the resulting value to the method.- Specified by:
- getin interface- Binding<byte[],- byte[]> 
- Parameters:
- ctx- The context object containing all argument objects.
- Throws:
- SQLException- Implementations are allowed to pass on all- SQLExceptions to the caller to be wrapped in- DataAccessExceptions.
 
- 
getDescription copied from interface:BindingGet aCallableStatement'sOUTvalue.Implementations are expected to produce a value by calling BindingGetStatementContext.value(Object), passing the resulting value to the method.- Specified by:
- getin interface- Binding<byte[],- byte[]> 
- Parameters:
- ctx- The context object containing all argument objects.
- Throws:
- SQLException- Implementations are allowed to pass on all- SQLExceptions to the caller to be wrapped in- DataAccessExceptions.
 
- 
getDescription copied from interface:BindingGet aSQLInput'sOUTvalue.Implementations are expected to produce a value by calling BindingGetSQLInputContext.value(Object), passing the resulting value to the method.- Specified by:
- getin interface- Binding<byte[],- byte[]> 
- Parameters:
- ctx- The context object containing all argument objects.
- Throws:
- SQLException- Implementations are allowed to pass on all- SQLExceptions to the caller to be wrapped in- DataAccessExceptions.
 
 
-