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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Java

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

Spring

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

MyBatis

MyBatisはJavaや.NET Frameworkでなどで使用できる、SQL文や、ストアドプロシージャをオブジェクトと紐付けるO/Rマッピングフレームワークです。

Spring Boot

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

Q&A

解決済

1回答

633閲覧

springでmybatisを使ってmysqlに接続できない

eggman

総合スコア21

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Java

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

Spring

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

MyBatis

MyBatisはJavaや.NET Frameworkでなどで使用できる、SQL文や、ストアドプロシージャをオブジェクトと紐付けるO/Rマッピングフレームワークです。

Spring Boot

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

0グッド

0クリップ

投稿2021/12/01 14:01

前提・実現したいこと

mybatisを使ってデータベースからデータを持ってきたい。
mapperクラスを作成して@Selectを使い、それをserviceクラスで使うようにしたい。

発生している問題・エラーメッセージ

Error creating bean with name 'userService': Unsatisfied dependency expressed through field 'userDao'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException:

該当のソースコード

UserDao

1package com.example.demo; 2 3import java.util.List; 4 5import org.apache.ibatis.annotations.Mapper; 6import org.apache.ibatis.annotations.Select; 7 8@Mapper 9public interface UserDao { 10 11 @Select("select * from user where id=#{id}") 12 User findById(int id); 13 14 @Select("select * from user") 15 List<User> findAll(); 16}

UserService

1package com.example.demo; 2 3import java.util.List; 4 5import org.springframework.beans.factory.annotation.Autowired; 6import org.springframework.stereotype.Service; 7 8@Service 9public class UserService { 10 11 @Autowired 12 private UserDao userDao; 13 14 public List<User> findAll() { 15 return userDao.findAll(); 16 } 17 18 public User findById(User user) { 19 return userDao.findById(user.getId()); 20 } 21 22}

index

1package com.example.demo; 2 3import org.springframework.beans.factory.annotation.Autowired; 4import org.springframework.stereotype.Controller; 5import org.springframework.web.bind.annotation.GetMapping; 6import org.springframework.web.bind.annotation.ModelAttribute; 7import org.springframework.web.bind.annotation.PostMapping; 8 9@Controller 10public class index { 11 12 @Autowired 13 private UserService userService; 14 15 //inputするためのリクエスト 16 @GetMapping("/login") 17 public String input(@ModelAttribute("user") User user) { 18 return "input"; 19 } 20 21 //入力された後のリクエスト 22 @PostMapping("/go") 23 public String register(@ModelAttribute("user") User user) { 24 return "result"; 25 } 26}

UserDaoがmapperとしての役割を担っています。

試したこと

エラー内容を見ると、userDaoがbeanとして認識されていないような気がします。
UserServiceクラスで認識できていないのでしょうか?

わかるかたいましたら、アドバイスいただけると嬉しいです。

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

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

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

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

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

m.ts10806

2021/12/01 14:08

>Unsatisfied dependency expressed through field で調べて出てくる情報では何か足りませんか?teratail内でも30件以上ヒットしました。 (質問内容から何をどう調べたのか分からないため聞いています)
eggman

2021/12/02 12:48

同じような質問は出てくるのですが、やはりわかりません。 beanとして認識されていないのでしょうか?
kiino

2021/12/02 15:19

使っているSpringBoot、MyBatisや JDK バージョンを教えてください build.gradle や pom.xml を概要欄に貼っていただきたいです
eggman

2021/12/02 15:23

自分のpropertiesの設定が間違っていました。 解決できました。
guest

回答1

0

自己解決

propertiesの設定が間違っていました。

投稿2021/12/02 15:22

eggman

総合スコア21

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問