質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.34%
JUnit

JUnitは、Javaで開発されたプログラムのユニットテストを行うためのアプリケーションフレームワークです。簡単にプログラムのユニットテストを自動化することができ、結果もわかりやすく表示されるため効率的に開発時間を短縮できます。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

Q&A

解決済

1回答

342閲覧

Spring で DbSetUp + H2 database によるデータ取得のテストで Like でのクエリがなぜかできず非常に困っています、、、、、

Hayato1201

総合スコア231

JUnit

JUnitは、Javaで開発されたプログラムのユニットテストを行うためのアプリケーションフレームワークです。簡単にプログラムのユニットテストを自動化することができ、結果もわかりやすく表示されるため効率的に開発時間を短縮できます。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

0グッド

0クリップ

投稿2024/05/24 09:31

実現したいこと

タイトルの通りですが、やりたいこととしては Spring boot のアプリケーションで db アクセスのあるクラスをテストしたいです。

ターゲットのクラスでは Specification を使っており、以下の様に使用します。

Java

1ReservationsSpecification specification = new TestSpecification(); 2Specification spec = Specification.where(specification.nameContain("タナカ")) 3 4List<TestEntity> user = target.findAll(query);

上記の TestSpecification クラスの nameContain は以下の様になっており、likeを使っています。

Java

1public Specification nameContain(String searchName) { 2 return searchName == null ? null : (root, query, builder) -> builder.like(root.get("name"), 3searchName + "%"); 4}

テストでは DbSetup と h2 database を使っていて
h2の設定が以下です。

yaml

1spring: 2 datasource: 3 driverClassName: org.h2.Driver 4 url: jdbc:h2:mem:testoracledb;MODE=Oracle;DB_CLOSE_DELAY=-1;INIT=CREATE SCHEMA IF NOT EXISTS TEST 5 username: username 6 password: password 7 h2.console.enabled: true

DbSetup では以下の様にデータを insert しています。

Java

1private final Operation INSERT_DATA = Operations.insertInto("TEST.SAMPLE") 2 .row() 3 .column("MANAGE_NO", "1") 4 .column("NAME","タナカタロウ")

単体テストではなく実際の Oracle の DB で実行した際には問題なく like で取得できています。
また、likeではなく以下のように equal による検索の場合は問題なく動きます。

Java

1public Specification nameContain(String searchName) { 2 return searchName == null ? null : (root, query, builder) -> builder.equal(root.get("name"), 3searchName); 4}

なぜ h2 で like の場合のみうまく取得できないか分からず非常に困っています。
何か原因お分かりになる方いましたらご教示いただけますと幸いです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

投稿2024/05/25 00:48

Hayato1201

総合スコア231

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.34%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問