From 27e2aa285a707b04022eb706fb8b7cf87368f56c Mon Sep 17 00:00:00 2001 From: Jens Schauder Date: Wed, 13 Jul 2022 05:22:36 +0200 Subject: [PATCH] Documentation for Query By Example. Original pull request #1195 See #1192 --- src/main/asciidoc/jdbc.adoc | 3 ++ src/main/asciidoc/query-by-example.adoc | 67 +++++++++++++++++++++++++ 2 files changed, 70 insertions(+) create mode 100644 src/main/asciidoc/query-by-example.adoc diff --git a/src/main/asciidoc/jdbc.adoc b/src/main/asciidoc/jdbc.adoc index 5ecad2f46b..a6432d388a 100644 --- a/src/main/asciidoc/jdbc.adoc +++ b/src/main/asciidoc/jdbc.adoc @@ -700,6 +700,9 @@ You can specify the following return types: * `int` (updated record count) * `boolean`(whether a record was updated) +include::{spring-data-commons-docs}/query-by-example.adoc[leveloffset=+1] +include::query-by-example.adoc[leveloffset=+1] + include::{spring-data-commons-docs}/repository-projections.adoc[leveloffset=+2] [[jdbc.mybatis]] diff --git a/src/main/asciidoc/query-by-example.adoc b/src/main/asciidoc/query-by-example.adoc new file mode 100644 index 0000000000..52dcc73853 --- /dev/null +++ b/src/main/asciidoc/query-by-example.adoc @@ -0,0 +1,67 @@ +[[query-by-example.running]] +== Running an Example + +In Spring Data JDBC, you can use Query by Example with Repositories, as shown in the following example: + +.Query by Example using a Repository +==== +[source, java] +---- +public interface PersonRepository + extends CrudRepository, + QueryByExampleExecutor { … } + +public class PersonService { + + @Autowired PersonRepository personRepository; + + public List findPeople(Person probe) { + return personRepository.findAll(Example.of(probe)); + } +} +---- +==== + +NOTE: Currently, only `SingularAttribute` properties can be used for property matching. + +The property specifier accepts property names (such as `firstname` and `lastname`). You can navigate by chaining properties together with dots (`address.city`). You can also tune it with matching options and case sensitivity. + +The following table shows the various `StringMatcher` options that you can use and the result of using them on a field named `firstname`: + +[cols="1,2", options="header"] +.`StringMatcher` options +|=== +| Matching +| Logical result + +| `DEFAULT` (case-sensitive) +| `firstname = ?0` + +| `DEFAULT` (case-insensitive) +| `LOWER(firstname) = LOWER(?0)` + +| `EXACT` (case-sensitive) +| `firstname = ?0` + +| `EXACT` (case-insensitive) +| `LOWER(firstname) = LOWER(?0)` + +| `STARTING` (case-sensitive) +| `firstname like ?0 + '%'` + +| `STARTING` (case-insensitive) +| `LOWER(firstname) like LOWER(?0) + '%'` + +| `ENDING` (case-sensitive) +| `firstname like '%' + ?0` + +| `ENDING` (case-insensitive) +| `LOWER(firstname) like '%' + LOWER(?0)` + +| `CONTAINING` (case-sensitive) +| `firstname like '%' + ?0 + '%'` + +| `CONTAINING` (case-insensitive) +| `LOWER(firstname) like '%' + LOWER(?0) + '%'` + +|===