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

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

新規登録して質問してみよう
ただいま回答率
85.35%
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回答

1390閲覧

SpringBootで結合せずに1つのページに複数のテーブル(Entity)を表示する方法

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/04/05 05:31

こんにちは。
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}

Repositoryクラス

Java

1package com.example.demo; 2 3import org.springframework.data.jpa.repository.JpaRepository; 4 5public interface AnimalRepository extends JpaRepository<Animal, Integer> { 6} 7

Java

1package com.example.demo; 2 3import org.springframework.data.jpa.repository.JpaRepository; 4 5public interface PlantRepository extends JpaRepository<Plant, Integer> { 6} 7

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 @Autowired 14 private AnimalRepository animalRepository; 15 private PlantRepository plantRepository; 16 17 //return html 18 @GetMapping("/Test") 19 public String getAnimalAndPlant(Model model) { 20 List<Animal> Animal = animalRepository.findAll(); 21 List<Plant> Plant = plantRepository.findAll(); 22 model.addAttribute("Animal", Animal); 23 model.addAttribute("Plant", Plant); 24 return "Test"; 25 } 26}

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

###分からないところ
このControllerの書き方だとどっちか片方でNullPointerExceptionが出てしまいます。

Controller内の1つの関数でこういった書き方をそもそもしていいのかどうか、
だめならどうすれば良いのかを教えてほしいです。

よろしくお願いします。

補足情報

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

annotationはそれぞれに付与してやる必要があります。

Java

1 @Autowired 2 private AnimalRepository animalRepository; 3 4 @Autowired 5 private PlantRepository plantRepository;

投稿2021/04/05 05:40

Luice

総合スコア771

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

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

K-actus

2021/04/05 05:44

知りませんでした…。 迅速な回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問