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

Enhance Readme file #583

Merged
merged 5 commits into from
Mar 24, 2024
Merged
Show file tree
Hide file tree
Changes from 3 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
23 changes: 22 additions & 1 deletion CHANGELOG.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,28 @@ and this project adheres to https://semver.org/spec/v2.0.0.html[Semantic Version

== [Unreleased]

== [1.0.0-M3] - 2024-02-2023
== [1.0.0-M4] - 2024-03-22

=== Changed

- clarify combined sort and keyset cursors
- Replace Sort by Sort<? super T> where appropriate

=== Added

- Introduce the Jakarta Data Query Language (JDQL)
- add Cursor.elements() method
- add Order.getSorts() method

=== Removed

- Remove BasicRepository.countBy() method
- BasicRepository.existsById() method
- BasicRepository.findByIdIn() method
- BasicRepository.deleteByIdIn() method
- BasicRepository.existsById() method

== [1.0.0-M3] - 2024-02-23

=== Changed

Expand Down
31 changes: 30 additions & 1 deletion README.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,35 @@ List<Product> found = products.findByNameLike(searchPattern, Order.by(
_Product.id.asc()));
----

== Jakarta Data Query Language (JDQL)

Jakarta Data introduces the Jakarta Data Query Language (JDQL), a streamlined query language designed to specify the semantics of query methods within Jakarta Data repositories. Utilizing the `@Query` annotation, JDQL allows developers to define queries straightforwardly and robustly.

JDQL is conceptualized as a subset of the Jakarta Persistence Query Language (JPQL). It inherits its syntax and functionality while being specifically tailored to accommodate the broad spectrum of data storage technologies supported by Jakarta Data. This design approach ensures that JDQL retains the expressiveness of SQL and JPQL yet simplifies its implementation across diverse data stores.
otaviojava marked this conversation as resolved.
Show resolved Hide resolved
otaviojava marked this conversation as resolved.
Show resolved Hide resolved

[source,java]
----
@Repository
public interface BookRepository extends BasicRepository<Book, UUID> {

// Find books with titles matching a specific pattern
@Query("where title like :titlePattern")
List<Book> booksMatchingTitle(String titlePattern);

// Select books by a specific author and sort them by title
@Query("where author.name = :author order by b.title")
otaviojava marked this conversation as resolved.
Show resolved Hide resolved
List<Book> findByAuthorSortedByTitle(String author);
}
----

*JDQL* supports three primary types of statements, reflecting the core operations typically required for data manipulation and retrieval in applications:

* *Select Statements*: Facilitate data retrieval from a data store, allowing for the specification of criteria to filter results.
* *Update Statements*: This option enables the modification of existing records in the data store based on specified criteria.
* *Delete Statements*: Allow for removing records from the data store that meet certain conditions.

This streamlined query language empowers developers to efficiently perform data access operations with minimal complexity, aligning with Jakarta Data's objective of simplifying data access across various storage technologies.

=== Maven

To start to use Jakarta Data, add the API as a Maven dependency:
Expand All @@ -117,7 +146,7 @@ To start to use Jakarta Data, add the API as a Maven dependency:
<dependency>
<groupId>jakarta.data</groupId>
<artifactId>jakarta.data-api</artifactId>
<version>1.0.0-M3</version>
<version>1.0.0-M4</version>
</dependency>
----

Expand Down