Quarkus - Doma - Runtime

Quarkus Extension for Doma

License

License

Categories

Categories

Quarkus Container Microservices Doma Data ORM
GroupId

GroupId

org.seasar.doma
ArtifactId

ArtifactId

doma-quarkus
Last Version

Last Version

1.1.0
Release Date

Release Date

Type

Type

jar
Description

Description

Quarkus - Doma - Runtime
Quarkus Extension for Doma

Download doma-quarkus

How to add to project

<!-- https://jarcasting.com/artifacts/org.seasar.doma/doma-quarkus/ -->
<dependency>
    <groupId>org.seasar.doma</groupId>
    <artifactId>doma-quarkus</artifactId>
    <version>1.1.0</version>
</dependency>
// https://jarcasting.com/artifacts/org.seasar.doma/doma-quarkus/
implementation 'org.seasar.doma:doma-quarkus:1.1.0'
// https://jarcasting.com/artifacts/org.seasar.doma/doma-quarkus/
implementation ("org.seasar.doma:doma-quarkus:1.1.0")
'org.seasar.doma:doma-quarkus:jar:1.1.0'
<dependency org="org.seasar.doma" name="doma-quarkus" rev="1.1.0">
  <artifact name="doma-quarkus" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.seasar.doma', module='doma-quarkus', version='1.1.0')
)
libraryDependencies += "org.seasar.doma" % "doma-quarkus" % "1.1.0"
[org.seasar.doma/doma-quarkus "1.1.0"]

Dependencies

compile (5)

Group / Artifact Type Version
io.quarkus : quarkus-core jar
io.quarkus : quarkus-arc jar
io.quarkus : quarkus-agroal jar
org.seasar.doma : doma-core jar 2.44.0
org.seasar.doma : doma-slf4j jar 2.44.0

Project Modules

There are no modules declared in this project.

Quarkus Extension for Doma

Notice

THIS REPOSITORY IS NOW FROZEN.

The new version is here: https://github.com/quarkiverse/quarkiverse-doma

Overview

Quarkus Extension for Doma provides the following features:

  • Hot reloading
  • Automatic bean register
  • Automatic SQL execution on startup
  • Configuration
  • Multiple Datasources
  • Support for native images

Build Status Google Group : doma-user Twitter

Hot reloading

In development mode, SQL and Script files are hot reloaded.

Automatic bean register

Our extension registers all DAO beans to the Quarkus CDI container automatically.

Automatic SQL import on startup

Our extension executes import.sql automatically when Doma starts.

Configuration

You can write the following configurations in your application.properties file:

quarkus.doma.sql-file-repository=greedy-cache
quarkus.doma.naming=none
quarkus.doma.exception-sql-log-type=none
quarkus.doma.dialect=h2
quarkus.doma.batch-size=10
quarkus.doma.fetch-size=50
quarkus.doma.max-rows=500
quarkus.doma.query-timeout=5000
quarkus.doma.sql-load-script=import.sql

The above properties are all optional.

See quarkus-doma.adoc for more details.

Multiple Datasources

You can bind Doma's configurations to each datasource as follows:

# default datasource
quarkus.datasource.db-kind=h2
quarkus.datasource.username=username-default
quarkus.datasource.jdbc.url=jdbc:h2:tcp://localhost/mem:default
quarkus.datasource.jdbc.min-size=3
quarkus.datasource.jdbc.max-size=13

# inventory datasource
quarkus.datasource.inventory.db-kind=h2
quarkus.datasource.inventory.username=username2
quarkus.datasource.inventory.jdbc.url=jdbc:h2:tcp://localhost/mem:inventory
quarkus.datasource.inventory.jdbc.min-size=2
quarkus.datasource.inventory.jdbc.max-size=12

# Doma's configuration bound to the above default datasource
quarkus.doma.dialect=h2
quarkus.doma.batch-size=10
quarkus.doma.fetch-size=50
quarkus.doma.max-rows=500
quarkus.doma.query-timeout=5000
quarkus.doma.sql-load-script=import.sql

# Doma's configuration bound to the above inventory datasource
quarkus.doma.inventory.dialect=h2
quarkus.doma.inventory.batch-size=10
quarkus.doma.inventory.fetch-size=50
quarkus.doma.inventory.max-rows=500
quarkus.doma.inventory.query-timeout=5000
quarkus.doma.inventory.sql-load-script=import.sql

You can inject the named Doma's resource using the io.quarkus.agroal.DataSource qualifier as follows:

@Inejct
Config defaultConfig;

@Inejct
Entityql defaultEntityql;

@Inejct
NativeSql defaultNativeSql;

@Inejct
@DataSource("inventory")
Config invetoryConfig;

@Inejct
@DataSource("inventory")
Entityql inventoryEntityql;

@Inejct
@DataSource("inventory")
NativeSql inventoryNativeSql;

Support for native images

Our extension recognizes reflective classes and resources, and includes them into your native image without additional configurations.

Supported Java version

Quarkus supports Java 8 or Java 11+ but Quarkus Extension for Doma requires Java 11+.

How to use

Gradle

dependencies {
    annotationProcessor "org.seasar.doma:doma-processor:2.44.0"
    implementation "org.seasar.doma:doma-core:2.44.0"
    implementation "org.seasar.doma:doma-quarkus-deployment:1.1.0"
}

Maven

...
<properties>
    <org.seasar.doma.version>2.44.0</org.seasar.doma.version>
    <org.seasar.doma-quarkus.version>1.1.0</org.seasar.doma-quarkus.version>
    <compiler-plugin.version>3.8.1</compiler-plugin.version>
</properties>
...
<dependencies>
    <dependency>
        <groupId>org.seasar.doma</groupId>
        <artifactId>doma-core</artifactId>
        <version>${org.seasar.doma.version}</version>
    </dependency>
    <dependency>
        <groupId>org.seasar.doma</groupId>
        <artifactId>doma-quarkus-deployment</artifactId>
        <version>${org.seasar.doma-quarkus.version}</version>
    </dependency>
</dependencies>
...
<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>${compiler-plugin.version}</version>
            <configuration>
                <source>11</source>
                <target>11</target>
                <!-- the parameters=true option is critical so that RESTEasy works fine -->
                <parameters>true</parameters>
                <annotationProcessorPaths>
                    <path>
                        <groupId>org.seasar.doma</groupId>
                        <artifactId>doma-processor</artifactId>
                        <version>${doma.version}</version>
                    </path>
                </annotationProcessorPaths>
            </configuration>
        </plugin>
    </plugins>
</build>

Sample project

Related information

org.seasar.doma

domaframework

Database mapping framework and related projects for Java

Versions

Version
1.1.0
1.0.4
1.0.3
1.0.2
1.0.1
1.0.0
0.5.0
0.4.0
0.3.0
0.2.0
0.1.0