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

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

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

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

Java

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

Spring

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

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

Spring Boot

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

Q&A

解決済

1回答

1304閲覧

Spring Bootでメッセージアプリケーションを作りたい

encho

総合スコア182

MySQL

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

Java

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

Spring

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

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

Spring Boot

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

1グッド

0クリップ

投稿2020/03/14 07:27

編集2020/03/15 04:21

#Spring Bootでメッセージアプリケーション
メッセージアプリケーションをSpring Bootで作っていますが
メッセージを送信した後にうまくDBに情報が保存されません。
どの部分に問題があるのかお分かりの方がいたらアドバイスをいただきたいです。

以下のように実行をしてみましたが、発行されたSQL文は

sql

1select message0_.message_id as message_1_4_, message0_.message_content as message_2_4_, message0_.message_time as message_3_4_, message0_.receiver_user_id as receiver4_4_, message0_.sender_user_id as sender_u5_4_ from message message0_ left outer join user user1_ on message0_.receiver_user_id=user1_.user_id where user1_.user_id=?

のようにselect文のみになっています。本来はメッセージテーブルに送信した情報を保存したいです。
おそらくは@ManyToOneにおけるDBへの保存方法に問題があると思うのですが
具体的にどの部分に問題があるのかが見当がつきません。
何かアドバイスをいただけると幸いです。

追記
まだ解決できていません。
何か情報をいただけると幸いです

使用環境
SpringBoot 2.2.4.
mysql 8.0.18

java

1@Entity 2@Transactional 3@NamedQuery(name="User.findAll", query="SELECT u FROM User u") 4public class User implements Serializable { 5 private static final long serialVersionUID = 1L; 6 7 @Id 8 @Column(name="user_id") 9 private int userId; 10 11 12 //bi-directional many-to-one association to Message 13 @OneToMany(mappedBy="senderUser") 14 private List<Message> messages1; 15 16 //bi-directional many-to-one association to Message 17 @OneToMany(mappedBy="receiverUser") 18 private List<Message> messages2; 19 20 public User() { 21 } 22 23 public int getUserId() { 24 return this.userId; 25 } 26 27 public void setUserId(int userId) { 28 this.userId = userId; 29 } 30 31 32 public List<Message> getMessages1() { 33 return this.messages1; 34 } 35 36 public void setMessages1(List<Message> messages1) { 37 this.messages1 = messages1; 38 } 39 40 public Message addMessages1(Message messages1) { 41 getMessages1().add(messages1); 42 messages1.setSenderUser(this); 43 44 return messages1; 45 } 46 47 public Message removeMessages1(Message messages1) { 48 getMessages1().remove(messages1); 49 messages1.setSenderUser(null); 50 51 return messages1; 52 } 53 54 public List<Message> getMessages2() { 55 return this.messages2; 56 } 57 58 public void setMessages2(List<Message> messages2) { 59 this.messages2 = messages2; 60 } 61 62 public Message addMessages2(Message messages2) { 63 getMessages2().add(messages2); 64 messages2.setReceiverUser(this); 65 66 return messages2; 67 } 68 69 public Message removeMessages2(Message messages2) { 70 getMessages2().remove(messages2); 71 messages2.setReceiverUser(null); 72 73 return messages2; 74 } 75 76 77}

java

1@Entity 2@NamedQuery(name="Message.findAll", query="SELECT m FROM Message m") 3public class Message implements Serializable { 4 private static final long serialVersionUID = 1L; 5 6 @Id 7 @GeneratedValue(strategy=GenerationType.IDENTITY) 8 @Column(name="message_id") 9 private long messageId; 10 11 @Column(name="message_content") 12 private String messageContent; 13 14 @Temporal(TemporalType.TIMESTAMP) 15 @Column(name="message_time") 16 private Date messageTime; 17 18 //送信者 19 @ManyToOne 20 @JoinColumn(name="sender_user_id") 21 private User senderUser; 22 23 //受信者 24 @ManyToOne 25 @JoinColumn(name="receiver_user_id") 26 private User receiverUser; 27 28 public Message() { 29 } 30 31 public long getMessageId() { 32 return this.messageId; 33 } 34 35 public void setMessageId(long messageId) { 36 this.messageId = messageId; 37 } 38 39 public String getMessageContent() { 40 return this.messageContent; 41 } 42 43 public void setMessageContent(String messageContent) { 44 this.messageContent = messageContent; 45 } 46 47 public Date getMessageTime() { 48 return this.messageTime; 49 } 50 51 public void setMessageTime(Date messageTime) { 52 this.messageTime = messageTime; 53 } 54 55 public User getSenderUser() { 56 return senderUser; 57 } 58 59 public void setSenderUser(User senderUser) { 60 this.senderUser = senderUser; 61 } 62 63 public User getReceiverUser() { 64 return receiverUser; 65 } 66 67 public void setReceiverUser(User receiverUser) { 68 this.receiverUser = receiverUser; 69 } 70

java

1@Controller 2@RequestMapping("profile") 3public class MessageController { 4 5 @Autowired 6 UserRepository userRepository; 7 @Autowired 8 MessageReposioty messageRepository; 9 10 @ModelAttribute 11 public MessageForm messageForm() { 12 return new MessageForm(); 13 } 14 15 @GetMapping("/{userId}/message") 16 String showMessage(@PathVariable("userId") Integer userId, 17 Model model) { 18 User senderUser = userRepository.findById(userId).orElse(null); 19 List<Message> recieveMessage = messageRepository.findByReceiverUser_UserId(userId); 20 model.addAttribute("recieveMessage",recieveMessage); 21 model.addAttribute("senderUser",senderUser); 22 return "profile/message"; 23 } 24 25 //送信時の処理 26 @PostMapping("/{userId}/message") 27 String sendMessage(@Validated MessageForm messageForm, 28 @AuthenticationPrincipal LoginUserDetails userDetails, 29 @PathVariable("userId") Integer userId, 30 Model model) { 31 User senderUser = userDetails.getUser(); 32 User receiverUser = userRepository.findById(userId).orElse(null); 33 Message message = new Message(); 34 message.setReceiverUser(receiverUser); 35 message.setSenderUser(senderUser); 36 message.setMessageContent(messageForm.getMessageContent()); 37 //ここでメッセージの保存を行うはず... 38 messageRepository.save(message); 39 return "redirect:{userId}/message"; 40 } 41} 42

html

1<!DOCTYPE html> 2<html xmlns:th="http://www.thymeleaf.org" 3 xmlns:sec="http://www.thymeleaf.org/extras/spring-security"> 4<head> 5<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> 6<title>Insert title here</title> 7</head> 8<body th:with="user = ${#authentication.principal.user}"> 9 <h1>メッセージ</h1> 10 <p th:text="${senderUser.userName}+'さんへメッセージを送る'"></p> 11 <form th:action="@{'/profile/'+${senderUser.userId}+'/message'}" th:object="${messageForm}"> 12 <textarea placeholder="メッセージを入力してください" th:field="*{messageContent}"> 13 </textarea> 14 <input type="submit"> 15 </form> 16</body> 17</html>

#ER図
イメージ説明

s.k👍を押しています

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

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

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

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

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

guest

回答1

0

自己解決

<form>をGETで送っているのにPostで受け取ろうとしていました method=postと変更して解決。

投稿2020/03/15 23:39

encho

総合スコア182

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問