🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Java

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

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Spring Boot

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

Q&A

1回答

2989閲覧

SpringBootsの実行時エラー: No property findEmployees found for type EmployeeInfo!

solli

総合スコア4

Java

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

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Spring Boot

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

0グッド

0クリップ

投稿2019/11/06 05:29

言語:java
FW : Spring Boot

spring bootを使ってログイン画面、一覧画面、詳細画面を表示する簡単なwebアプリケーションを作成しています。

ログイン画面の実装は終了し、
一覧画面の実装に入りましたがアプリ実行時エラーが出て詰まってしまいます。

やりたいこと
EmployeeInfoRepositoryImplクラスで employee_infoテーブルの(とりあえず)全件取得をしようとしていますが、 No property findEmployees found for type EmployeeInfo!というエラーが出てしまいます。

初心者&独学で大変困っております。どなたかご教授お願いします。

エラー内容

html

12019-11-06 14:09:35.987 ERROR 1635 --- [ main] o.s.boot.SpringApplication : Application run failed 2 3org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'listController': Unsatisfied dependency expressed through field 'listservice'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'listServiceImpl': Unsatisfied dependency expressed through field 'listRepository'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'employeeInfoRepository': Invocation of init method failed; nested exception is java.lang.IllegalArgumentException: Failed to create query for method public abstract java.util.List com.employee.repository.EmployeeInfoRepository.findEmployees()! No property findEmployees found for type EmployeeInfo! 4

関連するクラスを↓に貼ります。

EmployeeInfoRepository

java

1package com.employee.repository; 2 3import java.util.List; 4 5import org.springframework.data.jpa.repository.JpaRepository; 6import com.employee.entity.EmployeeInfo; 7 8public interface EmployeeInfoRepository extends JpaRepository<EmployeeInfo, String> { 9 10 public List<EmployeeInfo> findEmployees(); 11 12 13} 14

EmployeeInfoRepositoryImpl

package com.employee.repository; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.Query; import org.springframework.stereotype.Repository; import com.employee.entity.EmployeeInfo; @Repository public abstract class EmployeeInfoRepositoryImpl implements EmployeeInfoRepository { private EntityManager entityManager; @SuppressWarnings("unchecked") @Override public List<EmployeeInfo> findEmployees() { List<EmployeeInfo> empInfoList = null; //String sql = "FROM employee_info AS I INNER JOIN employee_state AS S ON S.employee_info_id = I.employee_id INNER JOIN company_info AS C ON C.company_id = I.company_info_id"; String sql = "FROM employee_info"; Query query = entityManager.createQuery(sql); empInfoList = query.getResultList(); return empInfoList; } }

以上になります。どなたかお助けいただけるとありがたいです!!

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

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

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

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

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

guest

回答1

0

EmployeeInfoRepositoryImplクラスの実装に問題があるようです。下記のように実装していますが、

@Repository public abstract class EmployeeInfoRepositoryImpl implements EmployeeInfoRepository { }

abstractだとインスタンスが生成できないので外してください。(もしくはこのEmployeeInfoRepositoryImplをextendsした具象クラスを作成してください)
・またEmployeeInfoRepositoryをimplementsするとこのインタフェースに定義されているメソッドをすべてオーバライドしなければならなくなるので、implementsしないようにしてください。(もしくはすべてのメソッドをオーバーライドしてください)

修正すると下記のようになります。インタフェースをimplementsしないようにすることでクラス名がおかしくなるので、ここでは暫定的にEmployeeInfoRepositoryServiceというクラス名に変えて説明を続けます。
同様にアノテーションも@Serviceに変えています。
この時点で質問文に記載のエラーは解消されると思います。

@Service public class EmployeeInfoRepositoryService { }

ただ、ほかにも実行時にエラーになる問題がありますので修正します。このままではEntityManagerは使えないので、Springにインジェクトしてもらう必要があります。下記のようにコンストラクタを宣言してインジェクトしてください。

@Service public class EmployeeInfoRepositoryService { private final EntityManager entityManager; public EmployeeInfoRepositoryService(EntityManager entityManager) { this.entityManager = entityManager; } }

クエリの書き方にも問題があるので修正します。sqlを"FROM employee_info";と書いていますがFROMには実テーブル名ではなくクラス名を記述します。
※なおTypedQueryを使っていますが、これはあくまでも一例なのでこのように書かなければいけないということではありません。

String sql = "FROM EmployeeInfo e"; TypedQuery<EmployeeInfo> query = entityManager.createQuery(sql, EmployeeInfo.class); List<EmployeeInfo> empInfoList = query.getResultList();

以上の修正でやりたいことの

EmployeeInfoRepositoryImplクラスで employee_infoテーブルの(とりあえず)全件取得をしようとしています

employee_infoテーブルのデータを取得することができると思います。

上記の実装はEntityManagerを使ってデータを取得する方法ですが、もっと簡単な方法としてEmployeeInfoRepositoryを使用する方法があります。

public interface EmployeeInfoRepository extends JpaRepository<EmployeeInfo, String> { public List<EmployeeInfo> findEmployees(); }

findEmployeesメソッドを宣言していますが不要なので削除します。
修正後は下記のようになります。

public interface EmployeeInfoRepository extends JpaRepository<EmployeeInfo, String> { }

あとはemployee_infoテーブルを取得したいクラスでこのリポジトリをインジェクトして使用します。
たとえばコントローラクラスで使用する場合、下記のようにインジェクトし、リポジトリのfindAllメソッドでデータを取得します。findAllはメソッド名の通りデータを全件取得します。

@RestController public class EmployeeInfoController { private final EmployeeInfoRepository repository; public EmployeeInfoController(EmployeeInfoRepository repository) { this.repository= repository; } @GetMapping(path = "list", produces = MediaType.APPLICATION_JSON_VALUE) public List<EmployeeInfo> findAll() { return repository.findAll(); } }

投稿2019/11/06 10:45

rubytomato

総合スコア1752

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

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

solli

2019/11/06 13:44

大変わかりやすいです。ありがとうございます! 1点、質問なのですが 外部結合したテーブルの値を取得する場合はfindAllメソッドや、 リポジトリのメソッドは使用できないよ思います。 外部結合されたテーブルの値を取得する場合はどんなメソッドを使用すればいいでしょうか? (findEmployeesメソッドを書いたのは、のちに独自のメソッドを作成しようとしたからです) すみませんが、よろしくお願いします。
rubytomato

2019/11/06 15:14

テーブルの関連はエンティティクラスで@OneToManyや@ManyToOneなどのアノテーションで表現するのですが、複雑な問い合わせの場合はJPQLで記述する必要があるかもしれません。 正確にお答えするには、具体的にどのようなクエリを発行したいかを知る必要がありますので、 エンティティクラスのソースコード(ないしはcreate table文)と、実行したいSQL文を質問内容に追記ください。 それと質問に質問で返すようで申し訳ありませんが、”やりたいこと”に記載されている > employee_infoテーブルの(とりあえず)全件取得をしようとしています という部分は解決できたのでしょうか?
solli

2019/11/24 04:15

オフラインの質問で解決できました! ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問