- All Superinterfaces:
Attachable,AttachableQueryPart,AutoCloseable,Flow.Publisher<Integer>,Publisher<Integer>,org.reactivestreams.Publisher<Integer>,Query,QueryPart,RowCountQuery,Serializable,Statement
Many RDBMS support procedural languages and in those languages, blocks are an
essential means of grouping logic and creating scope. Some databases support
executing anonymous blocks, in case of which the jOOQ Block can
be executed like any other Query. This works in a similar way as a
Batch containing multiple queries, but unlike a Batch, a
Block can contain procedural code as well.
Example:
// Assuming import static org.jooq.impl.DSL.*;
// Wrapping SQL statements only
using(configuration)
.begin(
insertInto(TABLE1).columns(TABLE1.COL).values(1),
insertInto(TABLE2).columns(TABLE2.COL).values(2),
insertInto(TABLE3).columns(TABLE3.COL).values(3)
)
.execute();
// Wrapping procedural code
Variable<Integer> i = var("i", SQLDataType.INTEGER);
using(configuration)
.begin(
for_(i).in(1, 3).loop(
insertInto(TABLE1).columns(TABLE1.COL).values(i)
)
)
.execute();
Instances can be created using DSL.begin(Statement...) and overloads.
- Author:
- Lukas Eder
-
Method Summary
Methods inherited from interface org.jooq.Attachable
attach, configuration, detachMethods inherited from interface org.jooq.AttachableQueryPart
getBindValues, getParam, getParams, getSQL, getSQLMethods inherited from interface org.reactivestreams.Publisher
subscribeMethods inherited from interface org.jooq.Query
bind, bind, cancel, close, execute, executeAsync, executeAsync, isExecutable, keepStatement, poolable, queryTimeout