Available in versions: Dev (3.20) | Latest (3.19) | 3.18 | 3.17 | 3.16 | 3.15 | 3.14 | 3.13 | 3.12 | 3.11 | 3.10

QueryParts

Applies to ✅ Open Source Edition   ✅ Express Edition   ✅ Professional Edition   ✅ Enterprise Edition

A org.jooq.Query and all its contained objects is a org.jooq.QueryPart. QueryParts essentially provide this functionality:

Both of these methods are contained in jOOQ's internal API's org.jooq.QueryPartInternal, which is internally implemented by every QueryPart.

The following sections explain some more details about SQL rendering and variable binding, as well as other implementation details about QueryParts in general.

Table of contents

3.24.1.
SQL rendering
3.24.2.
Declaration vs reference
3.24.3.
Pretty printing SQL
3.24.4.
Variable binding
3.24.5.
Custom data type bindings
3.24.6.
Custom syntax elements
3.24.7.
Plain SQL QueryParts
3.24.8.
Serializability
3.24.9.
SQL transformation
3.24.9.1.
ANSI JOIN to table lists
3.24.9.2.
Table lists to ANSI JOIN
3.24.9.3.
ROWNUM to LIMIT
3.24.9.4.
QUALIFY to derived table
3.24.9.5.
IN condition subquery with LIMIT to derived table
3.24.9.6.
Unnecessary arithmetic expressions
3.24.9.7.
Pattern based transformation (new)
3.24.9.7.1.
AND to NOT IN (new)
3.24.9.7.2.
Arithmetic expressions (new)
3.24.9.7.3.
COUNT(*) scalar subquery comparison (new)
3.24.9.7.4.
COUNT(expr) scalar subquery comparison (new)
3.24.9.7.5.
Empty scalar subquery (new)
3.24.9.7.6.
Hyperbolic functions (new)
3.24.9.7.7.
Idempotent function repetition (new)
3.24.9.7.8.
Inverse hyperbolic functions (new)
3.24.9.7.9.
Logarithmic functions (new)
3.24.9.7.10.
Merge AND predicates (new)
3.24.9.7.11.
Merge BIT_NOT with BIT_NAND (new)
3.24.9.7.12.
Merge BIT_NOT with BIT_NOR (new)
3.24.9.7.13.
Merge BIT_NOT with BIT_XNOR (new)
3.24.9.7.14.
Merge IN predicates (new)
3.24.9.7.15.
Merge NOT with comparison predicates (new)
3.24.9.7.16.
Merge NOT with DISTINCT predicate (new)
3.24.9.7.17.
Merge OR predicates (new)
3.24.9.7.18.
Merge range predicates (new)
3.24.9.7.19.
Normalise associative operations (new)
3.24.9.7.20.
Normalise fields compared to values (new)
3.24.9.7.21.
Normalise IN list with single element to comparison (new)
3.24.9.7.22.
OR to IN (new)
3.24.9.7.23.
Repeated arithmetic negation (new)
3.24.9.7.24.
Repeated bitwise negation (new)
3.24.9.7.25.
Repeated NOT (new)
3.24.9.7.26.
Trigonometric functions (new)
3.24.9.7.27.
Trim (new)
3.24.9.7.28.
Trivial case abbreviations (new)
3.24.9.7.29.
Trivial predicates (new)
3.24.10.
Custom SQL transformation with VisitListener
3.24.10.1.
Example: Logging abbreviated bind values

previous : next

Feedback

Do you have any feedback about this page? We'd love to hear it!

The jOOQ Logo