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

The jOOQ User Manual

Supported by ✅ Open Source Edition   ✅ Express Edition   ✅ Professional Edition   ✅ Enterprise Edition

Overview

This manual is divided into six main sections:

  • Getting started with jOOQ

    This section will get you started with jOOQ quickly. It contains simple explanations about what jOOQ is, what jOOQ isn't and how to set it up for the first time

  • SQL building

    This section explains all about the jOOQ syntax used for building queries through the query DSL and the query model API. It explains the central factories, the supported SQL statements and various other syntax elements

  • Code generation

    This section explains how to configure and use the built-in source code generator

  • SQL execution

    This section will get you through the specifics of what can be done with jOOQ at runtime, in order to execute queries, perform CRUD operations, import and export data, and hook into the jOOQ execution lifecycle for debugging

  • Reference

    This section is a reference for elements in this manual

Table of contents

1.
Copyright, License, and Trademarks
2.
Getting started with jOOQ
2.1.
How to read this manual
2.2.
The sample database used in this manual
2.3.
Different use cases for jOOQ
2.3.1.
jOOQ as a SQL builder without code generation
2.3.2.
jOOQ as a SQL builder with code generation
2.3.3.
jOOQ as a SQL executor
2.3.4.
jOOQ for CRUD
2.3.5.
jOOQ for PROs
2.4.
Downloading jOOQ
2.5.
Tutorials
2.5.1.
jOOQ in 7 easy steps
2.5.1.1.
Step 1: Preparation
2.5.1.2.
Step 2: Your database
2.5.1.3.
Step 3: Code generation
2.5.1.4.
Step 4: Connect to your database
2.5.1.5.
Step 5: Querying
2.5.1.6.
Step 6: Iterating
2.5.1.7.
Step 7: Explore!
2.5.2.
Using jOOQ with Flyway
2.5.3.
Using jOOQ with jbang
2.6.
jOOQ and Java 8
2.7.
jOOQ and Scala
2.8.
jOOQ and Groovy
2.9.
jOOQ and Kotlin
2.10.
jOOQ and NoSQL
2.11.
jOOQ and JPA
2.12.
Build your own
2.13.
jOOQ and backwards-compatibility
3.
SQL building
3.1.
The query DSL type
3.2.
The DSLContext API
3.2.1.
SQL Dialect
3.2.2.
SQL Dialect Family
3.2.3.
Connection vs. DataSource
3.2.4.
Custom data
3.2.5.
Custom ExecuteListeners
3.2.6.
Custom Unwrappers
3.2.7.
Custom Settings
3.2.7.1.
Auto-attach Records
3.2.7.2.
Backslash Escaping
3.2.7.3.
Batch size (new)
3.2.7.4.
Execute Logging
3.2.7.5.
Fetch Warnings
3.2.7.6.
Identifier style
3.2.7.7.
Implicit join type (new)
3.2.7.8.
Inline Threshold
3.2.7.9.
IN-list Padding
3.2.7.10.
Interpreter Configuration
3.2.7.11.
JDBC Flags
3.2.7.12.
Keyword style
3.2.7.13.
Listener Invocation Order
3.2.7.14.
Locales
3.2.7.15.
Map JPA Annotations
3.2.7.16.
Object qualification
3.2.7.17.
Optimistic Locking
3.2.7.18.
Parameter name prefix
3.2.7.19.
Parameter types
3.2.7.20.
Parser Configuration
3.2.7.21.
Reflection caching
3.2.7.22.
Rendering Configuration
3.2.7.23.
Return all columns on store
3.2.7.24.
Return Identity Value On Store
3.2.7.25.
Runtime catalog, schema and table mapping
3.2.7.26.
Scalar subqueries for stored functions
3.2.7.27.
Statement Type
3.2.7.28.
Updatable Primary Keys
3.2.8.
Thread safety
3.3.
SQL Statements (DML)
3.3.1.
jOOQ's DSL and model API
3.3.2.
The WITH clause
3.3.3.
The WITH RECURSIVE clause
3.3.4.
The SELECT statement
3.3.4.1.
SELECT clause
3.3.4.1.1.
Projection type safety
3.3.4.1.2.
SelectField
3.3.4.1.3.
SELECT *
3.3.4.1.4.
SELECT * EXCEPT (...)
3.3.4.1.5.
SELECT DISTINCT
3.3.4.1.6.
SELECT DISTINCT ON
3.3.4.1.7.
Convenience methods
3.3.4.2.
FROM clause
3.3.4.2.1.
JOIN operator
3.3.4.2.2.
Implicit path JOIN
3.3.4.3.
WHERE clause
3.3.4.4.
CONNECT BY clause
3.3.4.5.
GROUP BY clause
3.3.4.5.1.
GROUP BY columns
3.3.4.5.2.
GROUP BY ROLLUP
3.3.4.5.3.
GROUP BY CUBE
3.3.4.5.4.
GROUP BY GROUPING SETS
3.3.4.5.5.
GROUP BY empty grouping set
3.3.4.6.
HAVING clause
3.3.4.7.
WINDOW clause
3.3.4.8.
QUALIFY clause
3.3.4.9.
ORDER BY clause
3.3.4.9.1.
Ordering by field index
3.3.4.9.2.
Ordering and NULLS
3.3.4.9.3.
Ordering using CASE expressions
3.3.4.9.4.
Oracle's ORDER SIBLINGS BY clause
3.3.4.10.
LIMIT .. OFFSET clause
3.3.4.11.
WITH TIES clause
3.3.4.12.
SEEK clause
3.3.4.13.
FOR XML clause (new)
3.3.4.13.1.
AUTO mode (new)
3.3.4.13.2.
PATH mode (new)
3.3.4.13.3.
RAW mode (new)
3.3.4.13.4.
ROOT directive (new)
3.3.4.13.5.
ELEMENTS directive (new)
3.3.4.14.
FOR JSON clause
3.3.4.14.1.
AUTO mode (new)
3.3.4.14.2.
PATH mode (new)
3.3.4.14.3.
ROOT directive (new)
3.3.4.14.4.
INCLUDE_NULL_VALUES directive (new)
3.3.4.14.5.
WITHOUT_ARRAY_WRAPPER directive (new)
3.3.4.15.
FOR UPDATE clause
3.3.4.16.
Set operations
3.3.4.16.1.
Type safety
3.3.4.16.2.
Projection rowtype
3.3.4.16.3.
Differences to standard SQL
3.3.4.16.4.
UNION
3.3.4.16.5.
UNION ALL
3.3.4.16.6.
INTERSECT
3.3.4.16.7.
INTERSECT ALL
3.3.4.16.8.
EXCEPT
3.3.4.16.9.
EXCEPT ALL
3.3.4.17.
Lexical and logical SELECT clause order
3.3.5.
The INSERT statement
3.3.5.1.
INSERT .. VALUES
3.3.5.2.
INSERT .. DEFAULT VALUES
3.3.5.3.
INSERT .. SET
3.3.5.4.
INSERT .. SELECT
3.3.5.5.
INSERT .. ON DUPLICATE KEY UPDATE
3.3.5.6.
INSERT .. ON DUPLICATE KEY IGNORE
3.3.5.7.
INSERT .. ON CONFLICT
3.3.5.8.
INSERT .. RETURNING
3.3.6.
The UPDATE statement
3.3.6.1.
UPDATE .. SET
3.3.6.2.
UPDATE .. SET ROW
3.3.6.3.
UPDATE .. FROM
3.3.6.4.
UPDATE .. WHERE
3.3.6.5.
UPDATE .. ORDER BY .. LIMIT
3.3.6.6.
UPDATE .. RETURNING
3.3.7.
The DELETE statement
3.3.7.1.
DELETE .. USING
3.3.7.2.
DELETE .. WHERE
3.3.7.3.
DELETE .. ORDER BY .. LIMIT
3.3.7.4.
DELETE .. RETURNING
3.3.8.
The MERGE statement
3.3.8.1.
USING .. ON
3.3.8.2.
WHEN MATCHED THEN UPDATE
3.3.8.3.
WHEN MATCHED THEN DELETE
3.3.8.4.
WHEN MATCHED AND .. (new)
3.3.8.5.
WHEN NOT MATCHED THEN INSERT
3.4.
SQL Statements (DDL)
3.4.1.
The ALTER statement
3.4.1.1.
ALTER DATABASE (new)
3.4.1.1.1.
ALTER DATABASE .. RENAME (new)
3.4.1.1.2.
ALTER DATABASE IF EXISTS (new)
3.4.1.2.
ALTER DOMAIN (new)
3.4.1.2.1.
ALTER DOMAIN .. RENAME (new)
3.4.1.2.2.
ALTER DOMAIN .. SET DEFAULT (new)
3.4.1.2.3.
ALTER DOMAIN .. DROP DEFAULT (new)
3.4.1.2.4.
ALTER DOMAIN .. SET NOT NULL (new)
3.4.1.2.5.
ALTER DOMAIN .. DROP NOT NULL (new)
3.4.1.2.6.
ALTER DOMAIN .. ADD CONSTRAINT (new)
3.4.1.2.7.
ALTER DOMAIN .. RENAME CONSTRAINT (new)
3.4.1.2.8.
ALTER DOMAIN .. RENAME CONSTRAINT IF EXISTS (new)
3.4.1.2.9.
ALTER DOMAIN .. DROP CONSTRAINT (new)
3.4.1.2.10.
ALTER DOMAIN .. DROP CONSTRAINT IF EXISTS (new)
3.4.1.2.11.
ALTER DOMAIN IF EXISTS (new)
3.4.1.3.
ALTER INDEX
3.4.1.3.1.
ALTER INDEX .. RENAME
3.4.1.3.2.
ALTER INDEX IF EXISTS
3.4.1.4.
ALTER SCHEMA
3.4.1.4.1.
ALTER SCHEMA .. RENAME
3.4.1.4.2.
ALTER SCHEMA IF EXISTS
3.4.1.5.
ALTER SEQUENCE
3.4.1.5.1.
ALTER SEQUENCE .. RENAME
3.4.1.5.2.
ALTER SEQUENCE .. CACHE
3.4.1.5.3.
ALTER SEQUENCE .. CYCLE
3.4.1.5.4.
ALTER SEQUENCE .. MINVALUE
3.4.1.5.5.
ALTER SEQUENCE .. MAXVALUE
3.4.1.5.6.
ALTER SEQUENCE .. INCREMENT BY
3.4.1.5.7.
ALTER SEQUENCE .. START WITH
3.4.1.5.8.
ALTER SEQUENCE .. RESTART
3.4.1.5.9.
ALTER SEQUENCE IF EXISTS
3.4.1.6.
ALTER TABLE
3.4.1.6.1.
ALTER TABLE .. ADD COLUMN
3.4.1.6.2.
ALTER TABLE .. ADD COLUMN .. FIRST, BEFORE, AFTER
3.4.1.6.3.
ALTER TABLE .. ADD COLUMNS
3.4.1.6.4.
ALTER TABLE .. ADD COLUMN IF NOT EXISTS
3.4.1.6.5.
ALTER TABLE .. ADD PRIMARY KEY
3.4.1.6.6.
ALTER TABLE .. ADD UNIQUE
3.4.1.6.7.
ALTER TABLE .. ADD FOREIGN KEY
3.4.1.6.8.
ALTER TABLE .. ADD CHECK
3.4.1.6.9.
ALTER TABLE .. RENAME
3.4.1.6.10.
ALTER TABLE .. COMMENT
3.4.1.6.11.
ALTER TABLE .. ALTER COLUMN .. SET DEFAULT
3.4.1.6.12.
ALTER TABLE .. ALTER COLUMN .. DROP DEFAULT
3.4.1.6.13.
ALTER TABLE .. ALTER COLUMN .. SET NOT NULL
3.4.1.6.14.
ALTER TABLE .. ALTER COLUMN .. DROP NOT NULL
3.4.1.6.15.
ALTER TABLE .. ALTER COLUMN .. SET TYPE
3.4.1.6.16.
ALTER TABLE .. ALTER CONSTRAINT .. ENFORCED
3.4.1.6.17.
ALTER TABLE .. ALTER CONSTRAINT .. NOT ENFORCED
3.4.1.6.18.
ALTER TABLE .. RENAME COLUMN
3.4.1.6.19.
ALTER TABLE .. RENAME CONSTRAINT
3.4.1.6.20.
ALTER TABLE .. RENAME INDEX
3.4.1.6.21.
ALTER TABLE .. DROP COLUMN
3.4.1.6.22.
ALTER TABLE .. DROP COLUMN RESTRICT
3.4.1.6.23.
ALTER TABLE .. DROP COLUMN CASCADE
3.4.1.6.24.
ALTER TABLE .. DROP COLUMNS
3.4.1.6.25.
ALTER TABLE .. DROP COLUMN IF EXISTS
3.4.1.6.26.
ALTER TABLE .. DROP CONSTRAINT
3.4.1.6.27.
ALTER TABLE .. DROP PRIMARY KEY
3.4.1.6.28.
ALTER TABLE .. DROP UNIQUE
3.4.1.6.29.
ALTER TABLE .. DROP FOREIGN KEY
3.4.1.6.30.
ALTER TABLE .. DROP CONSTRAINT IF EXISTS
3.4.1.6.31.
ALTER TABLE IF EXISTS
3.4.1.7.
ALTER TYPE
3.4.1.7.1.
ALTER TYPE .. RENAME
3.4.1.7.2.
ALTER TYPE .. for enum alterations
3.4.1.8.
ALTER VIEW
3.4.1.8.1.
ALTER VIEW .. COMMENT
3.4.1.8.2.
ALTER VIEW .. RENAME
3.4.1.8.3.
ALTER VIEW IF EXISTS
3.4.2.
The COMMENT statement
3.4.2.1.
COMMENT ON COLUMN
3.4.2.2.
COMMENT ON TABLE
3.4.2.3.
COMMENT ON VIEW
3.4.3.
The CREATE statement
3.4.3.1.
CREATE DATABASE (new)
3.4.3.2.
CREATE DOMAIN (new)
3.4.3.3.
CREATE INDEX
3.4.3.4.
CREATE SCHEMA
3.4.3.5.
CREATE SEQUENCE
3.4.3.5.1.
CREATE SEQUENCE IF NOT EXISTS
3.4.3.5.2.
CREATE SEQUENCE .. CACHE
3.4.3.5.3.
CREATE SEQUENCE .. CYCLE
3.4.3.5.4.
CREATE SEQUENCE .. MINVALUE
3.4.3.5.5.
CREATE SEQUENCE .. MAXVALUE
3.4.3.5.6.
CREATE SEQUENCE .. INCREMENT BY
3.4.3.5.7.
CREATE SEQUENCE .. START WITH
3.4.3.6.
CREATE TABLE
3.4.3.6.1.
Columns
3.4.3.6.2.
Nullability
3.4.3.6.3.
Defaults
3.4.3.6.4.
Identities
3.4.3.6.5.
Primary key
3.4.3.6.6.
Unique constraints
3.4.3.6.7.
Foreign keys
3.4.3.6.8.
Check constraints
3.4.3.6.9.
From a SELECT
3.4.3.6.10.
Global temporary tables
3.4.3.7.
CREATE TYPE
3.4.3.8.
CREATE VIEW
3.4.3.8.1.
CREATE OR REPLACE VIEW
3.4.3.8.2.
WITH CHECK OPTION
3.4.3.8.3.
WITH READ ONLY
3.4.4.
The DROP statement
3.4.4.1.
DROP DATABASE (new)
3.4.4.1.1.
IF EXISTS (new)
3.4.4.2.
DROP DOMAIN (new)
3.4.4.2.1.
IF EXISTS (new)
3.4.4.3.
DROP INDEX
3.4.4.3.1.
IF EXISTS
3.4.4.4.
DROP SCHEMA
3.4.4.4.1.
IF EXISTS
3.4.4.5.
DROP SEQUENCE
3.4.4.5.1.
IF EXISTS
3.4.4.6.
DROP TABLE
3.4.4.6.1.
CASCADE
3.4.4.6.2.
IF EXISTS
3.4.4.7.
DROP TYPE
3.4.4.7.1.
IF EXISTS
3.4.4.8.
DROP VIEW
3.4.4.8.1.
IF EXISTS
3.4.5.
The GRANT statement
3.4.6.
The REVOKE statement
3.4.7.
The SET statement
3.4.7.1.
SET CATALOG
3.4.7.2.
SET SCHEMA
3.4.8.
The TRUNCATE statement
3.4.9.
Generating DDL from objects
3.5.
Procedural statements
3.5.1.
Block statement
3.5.2.
CONTINUE statement
3.5.3.
EXECUTE statement
3.5.4.
EXIT statement
3.5.5.
FOR statement
3.5.6.
GOTO statement
3.5.7.
IF statement
3.5.8.
Labels
3.5.9.
LOOP statement
3.5.10.
REPEAT statement
3.5.11.
Variables
3.5.12.
WHILE statement
3.6.
Catalog and schema expressions
3.7.
Table expressions
3.7.1.
Generated Tables
3.7.2.
Aliased Tables
3.7.2.1.
Aliased generated tables
3.7.2.2.
Aliased table expressions
3.7.2.3.
Derived column lists
3.7.2.4.
Unnamed derived tables
3.7.3.
Joined tables
3.7.3.1.
CROSS JOIN
3.7.3.2.
INNER JOIN
3.7.3.3.
OUTER JOIN
3.7.3.4.
SEMI JOIN
3.7.3.5.
ANTI JOIN
3.7.3.6.
ON clause
3.7.3.7.
ON KEY clause
3.7.3.8.
USING clause
3.7.3.9.
NATURAL clause
3.7.3.10.
LATERAL
3.7.3.11.
APPLY
3.7.3.12.
PARTITION BY
3.7.4.
The VALUES() table constructor
3.7.5.
Derived tables
3.7.6.
Inline derived tables
3.7.7.
The Oracle PIVOT clause
3.7.8.
Relational division
3.7.9.
Array and cursor unnesting
3.7.10.
Table-valued functions
3.7.11.
GENERATE_SERIES
3.7.12.
JSON_TABLE (new)
3.7.13.
XMLTABLE (new)
3.7.14.
The DUAL table
3.7.15.
Temporal tables
3.8.
Column expressions
3.8.1.
Table columns
3.8.1.1.
Generated table columns
3.8.1.2.
Dereferenced table columns
3.8.1.3.
Named table columns
3.8.2.
Aliased columns
3.8.3.
Cast expressions
3.8.4.
Datatype coercions
3.8.5.
Collations
3.8.6.
Arithmetic expressions
3.8.7.
String concatenation
3.8.8.
Case sensitivity with strings
3.8.9.
General functions
3.8.9.1.
CHOOSE
3.8.9.2.
COALESCE
3.8.9.3.
DECODE
3.8.9.4.
IIF
3.8.9.5.
NULLIF
3.8.9.6.
NVL
3.8.9.7.
NVL2
3.8.10.
Numeric functions
3.8.10.1.
ABS
3.8.10.2.
ACOS
3.8.10.3.
ASIN
3.8.10.4.
ATAN
3.8.10.5.
ATAN2
3.8.10.6.
CEIL
3.8.10.7.
COS
3.8.10.8.
COSH
3.8.10.9.
COT
3.8.10.10.
COTH
3.8.10.11.
DEG
3.8.10.12.
E
3.8.10.13.
EXP
3.8.10.14.
FLOOR
3.8.10.15.
GREATEST
3.8.10.16.
LEAST
3.8.10.17.
LN
3.8.10.18.
LOG
3.8.10.19.
NEG
3.8.10.20.
PI
3.8.10.21.
POWER
3.8.10.22.
RAD
3.8.10.23.
RAND
3.8.10.24.
ROUND
3.8.10.25.
SIGN
3.8.10.26.
SIN
3.8.10.27.
SINH
3.8.10.28.
SQRT
3.8.10.29.
TAN
3.8.10.30.
TANH
3.8.10.31.
TRUNC
3.8.10.32.
WIDTH_BUCKET
3.8.11.
Bitwise functions
3.8.11.1.
BIT_AND
3.8.11.2.
BIT_COUNT
3.8.11.3.
BIT_NAND
3.8.11.4.
BIT_NOR
3.8.11.5.
BIT_NOT
3.8.11.6.
BIT_OR
3.8.11.7.
BIT_XNOR
3.8.11.8.
BIT_XOR
3.8.11.9.
SHL
3.8.11.10.
SHR
3.8.12.
String functions
3.8.12.1.
ASCII
3.8.12.2.
BIT_LENGTH
3.8.12.3.
CONCAT (|| operator)
3.8.12.4.
LEFT
3.8.12.5.
LENGTH
3.8.12.6.
LOWER
3.8.12.7.
LPAD
3.8.12.8.
LTRIM
3.8.12.9.
MD5
3.8.12.10.
MID
3.8.12.11.
OCTET_LENGTH
3.8.12.12.
OVERLAY (new)
3.8.12.13.
POSITION
3.8.12.14.
REGEXP_REPLACE (new)
3.8.12.15.
REPEAT
3.8.12.16.
REPLACE
3.8.12.17.
REVERSE
3.8.12.18.
RIGHT
3.8.12.19.
RPAD
3.8.12.20.
RTRIM
3.8.12.21.
SPACE
3.8.12.22.
SUBSTRING
3.8.12.23.
TO_CHAR (new)
3.8.12.24.
TRANSLATE
3.8.12.25.
TRIM
3.8.12.26.
UPPER
3.8.13.
Datetime functions
3.8.13.1.
CENTURY
3.8.13.2.
CURRENT_DATE
3.8.13.3.
CURRENT_LOCALDATE
3.8.13.4.
CURRENT_LOCALDATETIME
3.8.13.5.
CURRENT_LOCALTIME
3.8.13.6.
CURRENT_OFFSETDATETIME
3.8.13.7.
CURRENT_OFFSETTIME
3.8.13.8.
CURRENT_TIME
3.8.13.9.
CURRENT_TIMESTAMP
3.8.13.10.
DATE
3.8.13.11.
DATEADD
3.8.13.12.
DATEDIFF
3.8.13.13.
DATESUB
3.8.13.14.
DAY
3.8.13.15.
DAY_OF_YEAR
3.8.13.16.
DECADE
3.8.13.17.
EPOCH
3.8.13.18.
EXTRACT
3.8.13.19.
HOUR
3.8.13.20.
ISO_DAY_OF_WEEK
3.8.13.21.
LOCALDATE
3.8.13.22.
LOCALDATEADD
3.8.13.23.
LOCALDATESUB
3.8.13.24.
LOCALDATETIME
3.8.13.25.
LOCALDATETIMEADD
3.8.13.26.
LOCALDATETIMESUB
3.8.13.27.
LOCALTIME
3.8.13.28.
MILLENNIUM
3.8.13.29.
MINUTE
3.8.13.30.
MONTH
3.8.13.31.
QUARTER
3.8.13.32.
SECOND
3.8.13.33.
TIME
3.8.13.34.
TIMESTAMP
3.8.13.35.
TIMESTAMPADD
3.8.13.36.
TIMESTAMPSUB
3.8.13.37.
TO_DATE
3.8.13.38.
TO_LOCALDATE
3.8.13.39.
TO_LOCALDATETIME
3.8.13.40.
TO_TIMESTAMP
3.8.13.41.
TRUNC
3.8.13.42.
YEAR
3.8.14.
ARRAY functions
3.8.14.1.
ARRAY_GET (new)
3.8.14.2.
ARRAY constructor
3.8.14.3.
CARDINALITY (new)
3.8.15.
JSON functions
3.8.15.1.
JSON_ARRAY
3.8.15.2.
JSON_OBJECT
3.8.15.3.
JSON_VALUE (new)
3.8.16.
XML functions (new)
3.8.16.1.
XMLATTRIBUTES (new)
3.8.16.2.
XMLCOMMENT (new)
3.8.16.3.
XMLCONCAT (new)
3.8.16.4.
XMLDOCUMENT (new)
3.8.16.5.
XMLELEMENT (new)
3.8.16.6.
XMLFOREST (new)
3.8.16.7.
XMLPARSE (new)
3.8.16.8.
XMLPI (new)
3.8.16.9.
XMLQUERY (new)
3.8.17.
CONNECT BY functions
3.8.17.1.
CONNECT_BY_ISCYCLE
3.8.17.2.
CONNECT_BY_ISLEAF
3.8.17.3.
CONNECT_BY_ROOT
3.8.17.4.
LEVEL
3.8.17.5.
PRIOR
3.8.17.6.
SYS_CONNECT_BY_PATH
3.8.18.
System functions
3.8.18.1.
CURRENT_SCHEMA
3.8.18.2.
CURRENT_USER
3.8.19.
Aggregate functions
3.8.19.1.
Grouping
3.8.19.2.
Distinctness
3.8.19.3.
Filtering
3.8.19.4.
Ordering
3.8.19.5.
Ordering WITHIN GROUP
3.8.19.6.
Keeping
3.8.19.7.
ARRAY_AGG
3.8.19.8.
AVG
3.8.19.9.
BOOL_AND
3.8.19.10.
BOOL_OR
3.8.19.11.
COLLECT
3.8.19.12.
COUNT
3.8.19.13.
CUME_DIST
3.8.19.14.
DENSE_RANK
3.8.19.15.
EVERY
3.8.19.16.
GROUP_CONCAT
3.8.19.17.
JSON_ARRAYAGG (new)
3.8.19.18.
JSON_OBJECTAGG (new)
3.8.19.19.
LISTAGG
3.8.19.20.
MAX
3.8.19.21.
MEDIAN
3.8.19.22.
MIN
3.8.19.23.
MODE (ordered)
3.8.19.24.
MODE (unordered)
3.8.19.25.
PERCENT_RANK
3.8.19.26.
PERCENTILE_CONT
3.8.19.27.
PERCENTILE_DISC
3.8.19.28.
PRODUCT
3.8.19.29.
RANK
3.8.19.30.
SUM
3.8.19.31.
XMLAGG (new)
3.8.20.
Window functions
3.8.20.1.
PARTITION BY
3.8.20.2.
ORDER BY
3.8.20.3.
ROWS, RANGE, GROUPS (frame clause)
3.8.20.4.
EXCLUDE
3.8.20.5.
NULL treatment
3.8.20.6.
FROM FIRST, FROM LAST
3.8.20.7.
Nested aggregate functions
3.8.20.8.
Window aggregation
3.8.20.9.
Window ordered aggregate
3.8.20.10.
ROW_NUMBER
3.8.20.11.
RANK
3.8.20.12.
DENSE_RANK
3.8.20.13.
PERCENT_RANK
3.8.20.14.
CUME_DIST
3.8.20.15.
NTILE
3.8.20.16.
LEAD
3.8.20.17.
LAG
3.8.20.18.
FIRST_VALUE
3.8.20.19.
LAST_VALUE
3.8.20.20.
NTH_VALUE
3.8.21.
User-defined functions
3.8.22.
User-defined aggregate functions
3.8.23.
The CASE expression
3.8.24.
Sequences and serials
3.8.25.
Scalar subqueries
3.8.26.
Tuples or row value expressions
3.9.
Conditional expressions
3.9.1.
Condition building
3.9.2.
TRUE and FALSE condition
3.9.3.
BOOLEAN columns
3.9.4.
AND, OR, NOT boolean operators
3.9.5.
Boolean operator precedence
3.9.6.
Comparison predicate
3.9.7.
Comparison predicate (degree > 1)
3.9.8.
Quantified comparison predicate
3.9.9.
BETWEEN predicate
3.9.10.
BETWEEN predicate (degree > 1)
3.9.11.
DISTINCT predicate
3.9.12.
DISTINCT predicate (degree > 1)
3.9.13.
DOCUMENT predicate (new)
3.9.14.
EXISTS predicate
3.9.15.
IN predicate
3.9.16.
IN predicate (degree > 1)
3.9.17.
JSON predicate
3.9.18.
JSON_EXISTS predicate (new)
3.9.19.
LIKE predicate
3.9.20.
LIKE REGEX predicate
3.9.21.
Quantified LIKE predicate
3.9.22.
NULL predicate
3.9.23.
NULL predicate (degree > 1)
3.9.24.
OVERLAPS predicate
3.9.25.
SIMILAR TO predicate
3.9.26.
UNIQUE predicate
3.9.27.
XMLEXISTS predicate (new)
3.9.28.
Query By Example (QBE)
3.10.
Operator precedence
3.11.
Data types
3.11.1.
Flags modifying data types
3.11.1.1.
Data type length
3.11.1.2.
Data type precision
3.11.1.3.
Data type scale
3.11.2.
Built-in data types
3.11.2.1.
BIGINT (Long)
3.11.2.2.
BIGINT UNSIGNED (ULong)
3.11.2.3.
BINARY (byte[])
3.11.2.4.
BIT (Boolean)
3.11.2.5.
BLOB (byte[])
3.11.2.6.
BOOLEAN (Boolean)
3.11.2.7.
CHAR (String)
3.11.2.8.
CLOB (String)
3.11.2.9.
DATE (Date)
3.11.2.10.
DECIMAL (BigDecimal)
3.11.2.11.
DECIMAL INTEGER (BigInteger)
3.11.2.12.
DOUBLE (Double)
3.11.2.13.
FLOAT (Double)
3.11.2.14.
INSTANT (Instant)
3.11.2.15.
INTEGER (Integer)
3.11.2.16.
INTEGER UNSIGNED (UInteger)
3.11.2.17.
INTERVAL (YearToSecond)
3.11.2.18.
INTERVAL DAY TO SECOND (DayToSecond)
3.11.2.19.
INTERVAL YEAR TO MONTH (YearToMonth)
3.11.2.20.
JSON (JSON)
3.11.2.21.
JSONB (JSONB)
3.11.2.22.
LOCALDATE (LocalDate)
3.11.2.23.
LOCALDATETIME (LocalDateTime)
3.11.2.24.
LOCALTIME (LocalTime)
3.11.2.25.
LONGNVARCHAR (String)
3.11.2.26.
LONGVARBINARY (byte[])
3.11.2.27.
LONGVARCHAR (String)
3.11.2.28.
NCHAR (String)
3.11.2.29.
NCLOB (String)
3.11.2.30.
NUMERIC (BigDecimal)
3.11.2.31.
NVARCHAR (String)
3.11.2.32.
OFFSETDATETIME (OffsetDateTime)
3.11.2.33.
OFFSETTIME (OffsetTime)
3.11.2.34.
OTHER (Object)
3.11.2.35.
REAL (Float)
3.11.2.36.
RECORD (Record)
3.11.2.37.
RESULT (Result)
3.11.2.38.
ROWID (RowId)
3.11.2.39.
SMALLINT (Short)
3.11.2.40.
SMALLINT UNSIGNED (UShort)
3.11.2.41.
TIME (Time)
3.11.2.42.
TIMESTAMP (Timestamp)
3.11.2.43.
TIMESTAMP WITH TIME ZONE (OffsetDateTime)
3.11.2.44.
TIME WITH TIME ZONE (OffsetTime)
3.11.2.45.
TINYINT (Byte)
3.11.2.46.
TINYINT UNSIGNED (UByte)
3.11.2.47.
UUID (UUID)
3.11.2.48.
VARBINARY (byte[])
3.11.2.49.
VARCHAR (String)
3.11.2.50.
XML (XML)
3.11.3.
Enum data types
3.11.4.
Domain data types
3.11.5.
User-defined data types (UDTs)
3.11.6.
Converted data types
3.11.6.1.
Custom data type Converter
3.11.6.2.
Custom data type Binding
3.12.
Synthetic SQL clauses
3.13.
Dynamic SQL
3.13.1.
Optional conditional expressions
3.14.
Plain SQL
3.14.1.
Plain SQL API
3.14.2.
Plain SQL templating language
3.15.
Hints
3.15.1.
MySQL hints
3.15.1.1.
Index hints
3.15.1.2.
STRAIGHT_JOIN
3.15.1.3.
Oracle style hints in MySQL
3.15.2.
Oracle hints
3.15.3.
SQL Server hints
3.15.3.1.
WITH
3.15.3.2.
OPTION
3.16.
SQL Parser
3.16.1.
SQL Parser API
3.16.2.
SQL Parser CLI
3.16.3.
SQL translator
3.16.4.
SQL Parser Grammar
3.17.
SQL interpreter
3.18.
Schema diff
3.19.
Schema diff CLI
3.20.
Names and identifiers
3.21.
Bind values and parameters
3.21.1.
Indexed parameters
3.21.2.
Named parameters
3.21.3.
Inlined parameters
3.21.4.
SQL injection
3.22.
QueryParts
3.22.1.
SQL rendering
3.22.2.
Declaration vs reference
3.22.3.
Pretty printing SQL
3.22.4.
Variable binding
3.22.5.
Custom syntax elements
3.22.6.
Plain SQL QueryParts
3.22.7.
Serializability
3.22.8.
SQL transformation
3.22.8.1.
ANSI JOIN to table lists
3.22.8.2.
Table lists to ANSI JOIN (new)
3.22.8.3.
ROWNUM to LIMIT (new)
3.22.8.4.
Unnecessary arithmetic expressions (new)
3.22.9.
Custom SQL transformation with VisitListener
3.22.9.1.
Example: Logging abbreviated bind values
3.23.
Zero-based vs one-based APIs
3.24.
SQL building in Kotlin (new)
3.24.1.
Kotlin BOOLEAN value expressions (new)
3.25.
SQL building in Scala
3.26.
Compile time validation
4.
SQL execution
4.1.
Comparison between jOOQ and JDBC
4.2.
Query vs. ResultQuery
4.3.
Fetching
4.3.1.
Record vs. TableRecord
4.3.2.
Record1 to Record22
4.3.3.
Arrays, Maps and Lists
4.3.4.
ResultQuery as Iterable
4.3.5.
RecordMapper
4.3.6.
POJOs
4.3.7.
RecordMapperProvider
4.3.8.
ConverterProvider (new)
4.3.9.
Lazy fetching
4.3.10.
Lazy fetching with Streams
4.3.11.
Many fetching
4.3.12.
Later fetching
4.3.13.
Reactive Fetching
4.3.14.
ResultSet fetching
4.3.15.
Auto data type conversion
4.3.16.
Custom data type conversion
4.3.17.
Data type lookups
4.4.
Static statements vs. Prepared Statements
4.5.
Reusing a Query's PreparedStatement
4.6.
JDBC flags
4.7.
Using JDBC batch operations
4.8.
Sequence execution
4.9.
Stored procedures and functions
4.9.1.
Oracle Packages
4.9.2.
Oracle member procedures
4.10.
Exporting to XML, CSV, JSON, HTML, Text, Charts
4.10.1.
Exporting XML
4.10.2.
Exporting CSV
4.10.3.
Exporting JSON
4.10.4.
Exporting HTML
4.10.5.
Exporting Text
4.10.6.
Exporting Charts
4.11.
Importing data
4.11.1.
The Loader API
4.11.2.
Import options
4.11.2.1.
Throttling
4.11.2.2.
Duplicate handling
4.11.2.3.
Error handling
4.11.3.
Import data sources
4.11.3.1.
Importing CSV
4.11.3.2.
Importing JSON
4.11.3.3.
Importing records
4.11.3.4.
Importing arrays
4.11.3.5.
Importing XML
4.11.4.
Import listeners
4.11.5.
Import result and error handling
4.12.
CRUD with UpdatableRecords
4.12.1.
Simple CRUD
4.12.2.
Records' internal flags
4.12.3.
IDENTITY values
4.12.4.
Navigation methods
4.12.5.
Non-updatable records
4.12.6.
Optimistic locking
4.12.7.
Batch execution
4.12.8.
CRUD SPI: RecordListener
4.13.
DAOs
4.14.
Transaction management
4.15.
Exception handling
4.16.
ExecuteListeners
4.17.
Database meta data
4.17.1.
JDBC meta data
4.17.2.
Interpreted meta data
4.17.3.
XML meta data
4.17.4.
Generated meta data
4.18.
JDBC Connection
4.19.
Batched Connection (new)
4.20.
Mocking Connection
4.21.
Mock File Database
4.22.
Parsing Connection
4.23.
Diagnostics
4.23.1.
Too Many Rows
4.23.2.
Too Many Columns
4.23.3.
Duplicate Statements
4.23.4.
Repeated statements
4.23.5.
WasNull calls
4.24.
Logging with LoggerListener
4.25.
Logging Connection
4.26.
Performance considerations
4.27.
Alternative execution models
4.27.1.
Using jOOQ with Spring's JdbcTemplate
4.27.2.
Using jOOQ with JPA
4.27.2.1.
Using jOOQ with JPA Native Query
4.27.2.2.
Using jOOQ with JPA entities
4.27.2.3.
Using jOOQ with JPA EntityResult
5.
Code generation
5.1.
Configuration and setup of the generator
5.2.
Advanced generator configuration
5.2.1.
Logging
5.2.2.
Error handling
5.2.3.
Jdbc
5.2.4.
Generator
5.2.5.
Database
5.2.5.1.
Database name and properties
5.2.5.2.
RegexFlags
5.2.5.3.
Includes and Excludes
5.2.5.4.
Include object types
5.2.5.5.
Record Version and Timestamp Fields
5.2.5.6.
Synthetic objects (new)
5.2.5.6.1.
Synthetic identities
5.2.5.6.2.
Synthetic primary keys
5.2.5.6.3.
Synthetic unique keys (new)
5.2.5.6.4.
Synthetic foreign keys (new)
5.2.5.7.
Date as timestamp
5.2.5.8.
Ignore procedure return values (deprecated)
5.2.5.9.
Unsigned types
5.2.5.10.
Catalog and schema mapping
5.2.5.11.
Catalog and schema version providers
5.2.5.12.
Custom ordering of generated code
5.2.5.13.
Forced types
5.2.5.13.1.
Matching of forced types
5.2.5.13.2.
Data type rewriting
5.2.5.13.3.
Qualified converters
5.2.5.13.4.
Inline converters
5.2.5.13.5.
Lambda converters (new)
5.2.5.13.6.
Enum converters
5.2.5.13.7.
Data type bindings
5.2.5.14.
Table valued functions
5.2.6.
Generate
5.2.6.1.
Annotations
5.2.6.2.
Covariant overrides
5.2.6.2.1.
Overriding as()
5.2.6.2.2.
Overriding rename()
5.2.6.3.
Default catalog and schema
5.2.6.4.
Fluent setters
5.2.6.5.
Fully Qualified Types
5.2.6.6.
Global Artefacts
5.2.6.7.
Implicit JOIN paths
5.2.6.8.
Java Time Types
5.2.6.9.
Serial Version UID (new)
5.2.6.10.
Sources
5.2.6.11.
Whitespace (newlines and indentation)
5.2.6.12.
Zero Scale Decimal Types
5.2.7.
Output target configuration
5.3.
Generated object types
5.3.1.
Generated tables
5.3.2.
Generated records
5.3.3.
Generated POJOs
5.3.4.
Generated Interfaces
5.3.5.
Generated DAOs
5.3.6.
Generated sequences
5.3.7.
Generated procedures
5.3.8.
Generated domains
5.3.9.
Generated UDTs
5.3.10.
Generated global artefacts
5.4.
Class names, method names, identifiers
5.4.1.
Custom generator strategies
5.4.2.
Matcher strategies
5.4.2.1.
MatcherRule
5.4.2.2.
Matching catalogs
5.4.2.3.
Matching schemas
5.4.2.4.
Matching tables
5.4.2.5.
Matching fields
5.4.2.6.
Matching routines
5.4.2.7.
Matching sequences
5.4.2.8.
Matching enums
5.4.2.9.
Matching embeddables
5.4.2.10.
Matcher examples
5.5.
Custom code sections
5.6.
Embeddable types (new)
5.6.1.
Configuration (new)
5.6.2.
Overlapping embeddable types (new)
5.6.3.
Field replacement (new)
5.6.4.
Embedded keys (new)
5.6.5.
Embedded domains (new)
5.7.
Input catalogs and schemas
5.8.
Alternative meta data sources
5.8.1.
JPADatabase: Code generation from entities
5.8.2.
XMLDatabase: Code generation from XML files
5.8.3.
DDLDatabase: Code generation from SQL files
5.8.4.
LiquibaseDatabase: Code generation from Liquibase XML, YAML, JSON files
5.9.
Alternative output languages
5.9.1.
XMLGenerator: Generating XML
5.9.2.
KotlinGenerator
5.9.3.
ScalaGenerator
5.10.
Code generation execution
5.10.1.
Running the code generator with Maven
5.10.2.
Running the code generator with Ant
5.10.3.
Running the code generator with Gradle
5.10.4.
Programmatic configuration and execution
5.11.
System properties governing code generation
5.12.
Code generation dependencies
5.13.
Code generation for large schemas
5.14.
Code generation and version control
5.15.
Features requiring generated code
6.
Coming from JPA
6.1.
Set based thinking
6.2.
Database first
6.3.
Eager or lazy loading
6.4.
First level cache and second level cache
6.5.
StatelessSession
6.6.
Embeddable (new)
6.7.
AttributeConverter
6.8.
User types
6.9.
Implicit JOIN
7.
Reference
7.1.
Supported RDBMS
7.2.
Commercial only features
7.3.
Experimental features
7.4.
SQL to DSL mapping rules
7.5.
Quality Assurance
7.6.
Security
7.6.1.
SQL Injection
7.6.2.
Debug logging
7.6.3.
Exception message
7.6.4.
Contact
7.7.
Migrating to jOOQ 3.0
7.8.
Don't do this
7.8.1.
jOOQ: Implementing the DSL types
7.8.2.
jOOQ: Referencing the Step types
7.8.3.
Schema: NULL columns
7.8.4.
Schema: Unnamed constraints
7.8.5.
Schema: Unnecessary surrogate keys
7.8.6.
Schema: Wrong data types
7.8.7.
SQL: COUNT(*) instead of EXISTS()
7.8.8.
SQL: N+1
7.8.9.
SQL: NATURAL JOIN or JOIN USING
7.8.10.
SQL: NOT IN predicate
7.8.11.
SQL: ORDER BY [column index]
7.8.12.
SQL: Rely on implicit ordering
7.8.13.
SQL: SELECT *
7.8.14.
SQL: SELECT DISTINCT
7.8.15.
SQL: Unnecessary UNION instead of UNION ALL
7.9.
The most important jOOQ types
7.10.
Credits

next

Feedback

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

The jOOQ Logo