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

Code generation

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

While optional, source code generation is one of jOOQ's main assets if you wish to increase developer productivity. jOOQ's code generator takes your database schema and reverse-engineers it into a set of Java classes modelling tables, records, sequences, POJOs, DAOs, stored procedures, user-defined types and many more.

The essential ideas behind source code generation are these:

  • Increased IDE support: Type your Java code directly against your database schema, with all type information available
  • Type-safety: When your database schema changes, your generated code will change as well. Removing columns will lead to compilation errors, which you can detect early.

The following chapters will show how to configure the code generator and how to generate various artefacts.

Table of contents

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 identities
5.2.5.7.
Synthetic primary keys
5.2.5.8.
Override primary keys
5.2.5.9.
Date as timestamp
5.2.5.10.
Ignore procedure return values (deprecated)
5.2.5.11.
Unsigned types
5.2.5.12.
Catalog and schema mapping
5.2.5.13.
Catalog and schema version providers
5.2.5.14.
Custom ordering of generated code
5.2.5.15.
Forced types
5.2.5.15.1.
Matching of forced types
5.2.5.15.2.
Data type rewriting
5.2.5.15.3.
Qualified converters
5.2.5.15.4.
Inline converters
5.2.5.15.5.
Enum converters
5.2.5.15.6.
Data type bindings
5.2.5.16.
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.
Sources (new)
5.2.6.10.
Whitespace (newlines and indentation)
5.2.6.11.
Zero Scale Decimal Types
5.2.7.
Output target configuration
5.3.
Programmatic generator configuration
5.4.
Custom generator strategies
5.5.
Matcher strategies
5.5.1.
MatcherRule
5.5.2.
Matching schemas
5.5.3.
Matching tables
5.5.4.
Matching fields
5.5.5.
Matching routines
5.5.6.
Matching sequences
5.5.7.
Matching enums
5.5.8.
Matcher examples
5.6.
Custom code sections
5.7.
Generated global artefacts
5.8.
Generated tables
5.9.
Generated records
5.10.
Generated POJOs
5.11.
Generated Interfaces
5.12.
Generated DAOs
5.13.
Generated sequences
5.14.
Generated procedures
5.15.
Generated UDTs
5.16.
Mapping generated catalogs and schemas
5.17.
Code generation for large schemas
5.18.
Code generation and version control
5.19.
JPADatabase: Code generation from entities
5.20.
XMLDatabase: Code generation from XML files
5.21.
DDLDatabase: Code generation from SQL files
5.22.
LiquibaseDatabase: Code generation from Liquibase XML, YAML, JSON files (new)
5.23.
XMLGenerator: Generating XML
5.24.
Running the code generator with Maven
5.25.
Running the code generator with Ant
5.26.
Running the code generator with Gradle
5.27.
System properties governing code generation
5.28.
Features requiring generated code

previous : next

Feedback

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

The jOOQ Logo