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

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

詳細はこちら
MySQL

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

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Gradle

Gradleは、ビルド自動化ツールです。 ソフトウェアパッケージやドキュメント、 または実際に何か他の種類のプロジェクトの構築、テスト、公開、展開などを自動化が出来ます

Spring Boot

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

Q&A

解決済

1回答

7887閲覧

SpringBootで1つのページに複数のテーブルを表示する方法

K-actus

総合スコア22

MySQL

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

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Gradle

Gradleは、ビルド自動化ツールです。 ソフトウェアパッケージやドキュメント、 または実際に何か他の種類のプロジェクトの構築、テスト、公開、展開などを自動化が出来ます

Spring Boot

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

0グッド

0クリップ

投稿2021/03/26 08:44

編集2021/03/26 08:46

こんにちは。
Javaについて初学者なので拙いところもあると思いますが、よろしくお願いします。

実現したいこと

SpringBootで、同じDB内にある複数のテーブルを1つの画面に表示させたいです。

ファイル構成は以下の通りです。
ファイル構成

###コード
HTML

html

1<!DOCTYPE html> 2<html> 3<head> 4<meta charset="UTF-8"> 5<title>Insert title here</title> 6</head> 7<body> 8 9<table> 10 <tr> 11 <th>名前</th> 12 <th>種類</th> 13 </tr> 14 <tr th:each="Animal: ${Animal}"> 15 <td th:text="${Animal.Name}"></td> 16 <td th:text="${Animal.Species}"></td> 17 </tr> 18</table> 19 20<table> 21 <tr> 22 <th>名前</th> 23 <th>種類</th> 24 </tr> 25 <tr th:each="Plant: ${Plant}"> 26 <td th:text="${Plant.Name}"></td> 27 <td th:text="${Plant.Species}"></td> 28 </tr> 29</table> 30</body> 31</html>

Entityクラス(互いに依存関係なし)

Java

1package com.example.demo; 2 3import javax.persistence.Column; 4import javax.persistence.Entity; 5import javax.persistence.GeneratedValue; 6import javax.persistence.GenerationType; 7import javax.persistence.Id; 8import javax.persistence.Table; 9 10import lombok.Getter; 11import lombok.Setter; 12 13@Getter 14@Setter 15@Entity 16@Table(name="animal") 17public class Animal { 18 19 @Id 20 @GeneratedValue(strategy=GenerationType.IDENTITY) 21 private int id; 22 23 @Column(name="Name") 24 private String Name; 25 26 @Column(name="Species") 27 private String Species; 28 29} 30

Java

1package com.example.demo; 2 3import javax.persistence.Column; 4import javax.persistence.Entity; 5import javax.persistence.GeneratedValue; 6import javax.persistence.GenerationType; 7import javax.persistence.Id; 8import javax.persistence.Table; 9 10import lombok.Getter; 11import lombok.Setter; 12 13@Getter 14@Setter 15@Entity 16@Table(name="plant") 17public class Plant { 18 19 @Id 20 @GeneratedValue(strategy=GenerationType.IDENTITY) 21 private int id; 22 23 @Column(name="Name") 24 private String Name; 25 26 @Column(name="Species") 27 private String Species; 28 29} 30

Applicationクラス

Java

1package com.example.demo; 2 3import org.springframework.boot.SpringApplication; 4import org.springframework.boot.autoconfigure.SpringBootApplication; 5 6@SpringBootApplication 7public class TestPrjApplication { 8 9 public static void main(String[] args) { 10 SpringApplication.run(TestPrjApplication.class, args); 11 } 12 13} 14

Repositoryクラス

Java

1package com.example.demo; 2 3import org.springframework.data.jpa.repository.JpaRepository; 4 5public interface TestRepository extends JpaRepository<Animal, Integer> { 6} 7 8//Plantはどうする?

Serviceクラス

Java

1package com.example.demo; 2 3import java.util.List; 4 5import org.springframework.beans.factory.annotation.Autowired; 6import org.springframework.stereotype.Service; 7import org.springframework.transaction.annotation.Transactional; 8@Service 9@Transactional 10public class TestService{ 11 12 @Autowired 13 TestRepository repository; 14 15 public List<Animal> selectAll() { 16 return repository.findAll(); 17 } 18 19 //Plantはどうする? 20 21}

Controllerクラス

Java

1package com.example.demo; 2 3import java.util.List; 4 5import org.springframework.beans.factory.annotation.Autowired; 6import org.springframework.stereotype.Controller; 7import org.springframework.ui.Model; 8import org.springframework.web.bind.annotation.GetMapping; 9 10 11@Controller 12public class TestController { 13 14 @Autowired 15 TestService service; 16 17 //return html 18 @GetMapping("/Test") 19 public String getAnimal(Model model) { 20 List<Animal> Animal = service.selectAll(); 21 model.addAttribute("Animal", Animal); 22 return "Test"; 23 } 24 25 //getPlantはどうする? 26 27}

build.gradle

plugins { id 'org.springframework.boot' version '2.4.3' id 'io.spring.dependency-management' version '1.0.11.RELEASE' id 'java' } group = 'com.example' version = '0.0.1-SNAPSHOT' apply plugin: 'war' sourceCompatibility = '11' repositories { mavenCentral() } dependencies { implementation 'org.springframework.boot:spring-boot-starter-thymeleaf' implementation 'org.springframework.boot:spring-boot-starter-web' runtimeOnly 'mysql:mysql-connector-java' testImplementation 'org.springframework.boot:spring-boot-starter-test' //1 : jpa compile 'org.springframework.boot:spring-boot-starter-data-jpa' //2 : mysql connector compile 'mysql:mysql-connector-java' //3 : tymeleaf compile('org.springframework.boot:spring-boot-starter-thymeleaf') implementation 'org.springframework.boot:spring-boot-starter-web' testImplementation 'org.springframework.boot:spring-boot-starter-test' //lombok // https://mvnrepository.com/artifact/org.projectlombok/lombok compile group: 'org.projectlombok', name: 'lombok', version: '1.18.18' } test { useJUnitPlatform() }

application.propties

spring.jpa.hibernate.ddl-auto=none spring.datasource.url=jdbc:mysql://localhost:3306/Testdb spring.datasource.username=root spring.datasource.password=password #デフォルトの命名規則を無視 #https://stackoverflow.com/questions/38646025/set-table-name-in-spring-jpa spring.jpa.hibernate.naming.implicit-strategy=org.hibernate.boot.model.naming.ImplicitNamingStrategyLegacyJpaImpl spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl #キャッシュを無効 spring.messages.cache-seconds = 0

###分からないところ
Entityクラスを複数作成した後、それをまとめるクラスを作ってそれに対して一括で扱えるRepositoryやService、Controllerを作成したいのですが、
調べてもどう書くか出てきません。(そもそもこの発想が間違ってますか?)

回答よろしくお願いします。

###参考サイト
https://morelia.tokyo/java/springboot-mysql-insert-select-data/
https://dev.classmethod.jp/articles/using_spring_boot_2/

補足情報

Eclipse 2020 Java FullEdition
AmazonCorretto jdk15.0.2_7
SpringBoot 2.4.3
MySQL 8.0.23
Windows10 Pro 1909

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

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

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

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

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

guest

回答1

0

ベストアンサー

Entityクラスを複数作成した後、それをまとめるクラスを作ってそれに対して一括で扱えるRepositoryやService、Controllerを作成したい

1つのサービスの中では1つのリポジトリしか使えないとか、1つのコントローラの中では1つのサービスしか使えないとか、そんな決まりは無いので、自由に組み合わせて作ってみたら良いと思いますよ。

とは言え、下のレイヤから、リポジトリ層、サービス層、コントローラ層と見たとき、リポジトリ層はエンティティと1対1に対応させることが多いと思います。

よって、私なら、AnimalRepositoryPlantRepositoryを作り、それぞれのエンティティのDBアクセスメソッドを定義します。

一方、サービス層は、そのWebアプリの機能を強く反映したものになると思います。

例えば、アプリがAnimalのCRUD機能を持つなら、AnimalServiceは必要でしょうね(その中でAnimalRepositoryを使う)。かといって、常にリポジトリとサービスを1対1に対応させる必要も無いです。例えば、このWebアプリに、動物と植物を1つずつランダムにペアリングして表示する機能があるなら、LifeServiceクラスを作って、その中で2つのリポジトリを使う、みたいな構成にしても良いでしょう。

java

1public class LifeService { 2 private AnimalRepository animalRepository; 3 private PlantRepository plantRepository; 4 public LifePairDto randomLifePair() { 5 ... 6 } 7 ... 8} 9 10public class LifePairDto { 11 private Animal animal; 12 private Plant plant; 13 public LifePairDto(Animal a, Plant p) { 14 ... 15 } 16 ... 17} 18// ※アノテーションとか諸々、省略してます。

回答になってるかな…。

投稿2021/03/26 11:39

gpsoft

総合スコア1323

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

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

K-actus

2021/03/29 02:05 編集

回答ありがとうございます。 その例で省略せずに書くとどうなるか教えてほしいです。
K_3578

2021/03/29 02:12

横槍失礼します。 >その例で省略せずに書くとどうなるか教えてほしいです。 質問者さんの言っていることはほぼ「作業依頼」に当たります。 例示して頂いてる内容を基に自分で考えてみてください。
K-actus

2021/03/29 02:28 編集

質問を変更します。 挙げてくださった例だとLifeServiceクラス内のrandomLifePair内でreturnすれば良いと思ってるんですけど、 クラスを分けているのはオブジェクト指向に則っているという解釈でいいですか? Serviceクラスについての理解が曖昧ですみません。
gpsoft

2021/03/29 03:59

質問の意図が読み取れないので、以下の2点を補足していただけますか? 「randomLifePair内でreturnすれば良い」→「何を」returnする? 「クラスを分けている」→「何クラス」と「何クラス」に分けている?
K-actus

2021/03/29 05:11

言葉足らずですみません。 本質問内ではTestServiceクラスのselectAll()でデータをどう取ってくるか返してるんですけど、 回答でLifeServiceクラスとLifePairDtoに分けているのはオブジェクト指向に則っているという解釈でいいですか? という意味です。
gpsoft

2021/03/29 21:50

LifePairDtoとLifeServiceに「分けた」つもりは無いです。LifePairDtoは、単にAnimalとPlantを合体しただけの「容器」的クラスですね(Modelに近い)。サービス層とコントローラ層(さらにView層)との間でデータをやりとりするのに利用する感じです。 OOPに則っているかどうかは私には分かりません。少なくともYES/NOで答えるのは難しいです。
K-actus

2021/03/30 02:32

LifePairDtoクラスのようなものもServiceのファイルに記述するべきなんですか?
Luice

2021/03/30 02:54

この話、この問題の解決に必要な事ですか?
gpsoft

2021/03/30 21:50

>LifePairDtoクラスのようなものもServiceのファイルに記述するべきなんですか? 2つのクラスを同じソースファイルに記述すべき、という意図は無いです(諸々、省略してますので、ご自分で試してみてください)。私ならソースファイルは分けますね。そもそも、どちらもpublicなクラスなので、ソースファイルを分けないとコンパイルが通らないんじゃないかな。
K-actus

2021/04/05 03:55

すみません。Serviceクラスを使わないことにしたので質問を作成し直します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問