YDB ORM for Java (YOJ) is a lightweight ORM for immutable entities.
YOJ integrates well with YDB, and it also has an in-memory repository implementation with YDB-like semantics for lightning-fast persistence tests.
YOJ is licensed under Apache License, Version 2.0.
If you wish to contribute to YOJ, see the Notice to external contributors, and follow the guidelines.
To use YOJ in your project, just add YOJ BOM (Bill of Materials) to your Maven <dependencies>
:
<dependency>
<groupId>tech.ydb.yoj</groupId>
<artifactId>yoj-bom</artifactId>
<version>2.5.2</version>
<type>pom</type>
<scope>import</scope>
</dependency>
Then depend on just the modules you need, specifying only groupId
=tech.ydb.yoj
and artifactId
=yoj-<module>
(see <module>
names below).
🦔 YOJ consists of the following modules:
databind
: Core data-binding logic used to convert between Java objects and database rows (or anything representable by a JavaMap
, really).repository
: Core abstractions and APIs for entities, repositories, transactions etc. Entity API is designed to be minimally intrusive, so that your domain objects (with all the juicy business logic!) can easily become entities.repository-ydb-v2
: Repository API implementation for YDB. Uses YDB SDK v2.x. Recommended.repository-inmemory
: In-Memory Repository API implementation using persistent data structures from Eclipse Collections. Has YDB-like semantics for data modification, to easily and quickly test your business logic without spinning containers or accessing a real YDB installation. Highly recommended.repository-ydb-common
: Common Logic for all YDB Repository implementations, regardless of the YDB SDK version used.repository-test
: Basic tests which all Repository implementations must pass.json-jackson-v2
: Support for JSON serialization and deserialization of entity fields, using Jackson 2.x.aspect
: AspectJ aspect and@YojTransactional
annotation for usage with AspectJ and Spring AOP. Allows a Spring@Transactional
-like experience for your methods that need to initiate or continue a YDB transaction.ext-meta-generator
: Annotation processor that generates field paths for each of yourEntity
fields, to be used withTableQueryBuilder
(Table.query()
DSL) andYqlPredicate
.util
: Utility classes used in YOJ implementation.