Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Increase documentation about new features at Spec and readme #295

Merged
merged 17 commits into from
Oct 16, 2023
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
63 changes: 62 additions & 1 deletion README.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,9 @@ Jakarta Data’s goal is to provide a familiar and consistent, Jakarta-based pro

=== Repository

A repository abstraction designed to significantly reduce the boilerplate code required to implement data access layers for various types of persistent stores.
Jakarta Data provides repository abstractions designed to streamline the development of data access layers for various persistent stores, eliminating the need for extensive boilerplate code. These repository abstractions are broadly classified into two categories:

* *Built-in Repository Interfaces*: Jakarta Data offers a hierarchy of built-in repository interfaces. The root of this hierarchy is the `DataRepository` interface, which includes several specialized interfaces like `CrudRepository`, `KeyValueRepository`, and more. These interfaces are designed to handle common data access operations and provide a solid foundation for your data layer.
otaviojava marked this conversation as resolved.
Show resolved Hide resolved

[source,java]
----
Expand All @@ -33,6 +35,32 @@ Car ferrari = Car.id(10L).name("Ferrari").type(CarType.SPORT);
repository.save(ferrari);
----

* *Custom Repository Interfaces*: Besides the built-in repository interfaces, Jakarta Data enables you to create custom repository interfaces tailored to your domain requirements. These custom interfaces serve as a bridge between your domain's semantics and the underlying database operations. With annotations like `Insert`, `Update`, `Delete`, and `Save`, you can define expressive and domain-specific repository methods that align seamlessly with your application's needs.

[source,java]
----
@Repository
public interface Garage {

@Save
Car park(Car car);
otaviojava marked this conversation as resolved.
Show resolved Hide resolved

}
----


[source,java]
----
@Inject
Garage garage;
...
Car ferrari = Car.id(10L).name("Ferrari").type(CarType.SPORT);
repository.park(ferrari);
----

Whether you use built-in repository interfaces or create custom repositories, Jakarta Data empowers you to write more concise and expressive data access layers while reducing the need for boilerplate code.


==== Pagination

Jakarta Data also supports parameters to define pagination and sorting.
Expand All @@ -48,6 +76,39 @@ public interface ProductRepository extends PageableRepository<Product, Long> {
}
----

==== Type-safe Access to Entity Attributes

Jakarta Data provides a static metamodel that allows entity attributes to be accessed by applications in a type-safe manner. This metamodel generates metadata classes that mirror your entity classes, enabling you to work with entity attributes using compile-time safety.

With the Jakarta Data static metamodel, you can access entity attributes in a type-safe manner. Here's a quick example to demonstrate how it works:

[source,java]
----

@Entity
public class Product {
public long id;
public String name;
public float price;
}
----


Usage example:

[source,java]
----

List<Product> found = products.findByNameContains(searchPattern,
Product_.price.desc(),
Product_.name.asc(),
Product_.id.asc());
----


In this example, `Product_` is the metadata class generated by Jakarta Data, allowing you to access entity attributes in a type-safe way. It helps prevent runtime errors related to attribute names and enables more reliable and efficient data access.


otaviojava marked this conversation as resolved.
Show resolved Hide resolved
=== Maven

To start to use Jakarta Data, add the API as a Maven dependency:
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{"checksum":"ditaa-md5-31a2b84bb14821a6b73c42811e2a847f","options":{"scale":null,"tabs":null,"background":null,"antialias":null,"separation":null,"round_corners":null,"shadows":null,"debug":null,"fixed_slope":null,"transparent":null,"bullet_characters":null},"width":500,"height":266}
29 changes: 27 additions & 2 deletions spec/src/main/asciidoc/repository.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ Several vital characteristics define repositories:

Repositories in Jakarta Data serve as efficient gateways for managing and interacting with persistent data, offering a simplified and consistent approach to data access and modification within Java applications.

The parent interface at the root of the hierarchy of built-in interfaces is `DataRepository`. All of the built-in interfaces are extensible. A repository might extend one or more of the built-in interfaces or none of them. Method signatures that are copied from the built-in interfaces to a repository must have the same behavior as defined on the built-in interface.
The Jakarta Data specification currently supports two types of repositories. The first type consists of built-in interfaces that are parent interfaces from which repositories can inherit. At the root of this hierarchy is the `DataRepository` interface. These built-in interfaces are extensible, meaning a repository can extend one or more of them or none at all. When a repository extends a built-in interface, the method signatures copied from the built-in interfaces must retain the same behavior as defined in the built-in interfaces.
otaviojava marked this conversation as resolved.
Show resolved Hide resolved

[ditaa]
....
Expand Down Expand Up @@ -108,10 +108,34 @@ Jakarta Data empowers developers to take control of their data access and manage

2. **Repository Interfaces:** Jakarta Data encourages the creation of one or more repository interfaces, following predefined rules that include the guidelines set forth by this specification. These interfaces are the gateways to accessing and manipulating the data, offering a structured and efficient way to perform data operations.


Subsequently, an implementation of Jakarta Data, specifically tailored to the chosen data store, assumes the responsibility of implementing each repository interface. This symbiotic relationship between developers and Jakarta Data ensures that data access and manipulation remain consistent, efficient, and aligned with best practices.

Jakarta Data empowers developers to shape their data access strategies by defining entity classes and repositories, with implementations seamlessly adapting to the chosen data store. This flexibility and Jakarta Data's persistence-agnostic approach promote robust data management within Java applications.

Additionally, Jakarta Data allows for custom interfaces that do not extend any built-in interfaces. These non-built-in interfaces enable developers to define their repository structures and behavior.

Non-built-in interfaces play a pivotal role in Jakarta Data, offering a powerful mechanism for creating custom repository interfaces that align seamlessly with your specific domain requirements. These custom interfaces provide a means to define your domain's ubiquitous language precisely.

In this context, database operations involving fundamental data changes, such as insertion, update, and removal, are realized through the strategic utilization of annotations like `Insert`, `Update`, `Delete`, and `Save`. These annotations enable the crafting of expressive and contextually meaningful repository methods, resulting in a repository that closely mirrors the semantics of your domain.

For instance, consider the 'Garage' repository interface below:

[source,java]
----
@Repository
public interface Garage {

@Save
Car park(Car car);

@Delete
void unpark(Car car);
}
----

Here, the `@Save` annotation is used for the `park` method, allowing you to design a repository interface that encapsulates the essence of your domain. This approach fosters a shared understanding and more intuitive communication within your development team, ensuring that your database operations are integral to your domain's language.
otaviojava marked this conversation as resolved.
Show resolved Hide resolved
=======
otaviojava marked this conversation as resolved.
Show resolved Hide resolved
=== Repository interfaces

A Jakarta Data repository is a Java interface annotated `@Repository`.
Expand Down Expand Up @@ -140,7 +164,7 @@ Repositories perform operations on entities. For repository methods that are ann

Users of Jakarta Data declare a primary entity type for a repository by inheriting from a built-in repository super interface, such as `BasicRepository`, and specifying the primary entity type as the first type variable. The primary entity type is assumed for methods that do not otherwise specify an entity type, such as `countByPriceLessThan`. Methods that require a primary entity type raise `MappingException` if a primary entity type is not provided.

[NOTE]

NOTE: A Jakarta Data provider might go beyond what is required by this specification and support abstract methods which do not fall into any of the above categories.

Such functionality is not defined by this specification, and so programs with repositories which declare such methods are not portable between providers.
Expand Down Expand Up @@ -345,6 +369,7 @@ public interface ProductRepository extends CrudRepository<Product, Long> {
}
----


=== Entity Classes

In Jakarta Data, an entity refers to a fundamental data representation and management building block. It can be conceptually understood in several aspects:
Expand Down