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

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

ただいまの
回答率

87.48%

Spring Boot + Spring Data JPAでテーブルを結合したい

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,232

score 14

前提・実現したいこと

Spring Boot + Spring Data JPAでテーブルを結合したいです。
SQL文が間違っているのだと思いますが、悩みすぎて頭が沸騰し、正常な思考が出来なくなってしまったのでお助けください。

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

Caused by: org.hibernate.QueryException: could not resolve property: shop_id of: com.example.pizza.entity.Customer
Caused by: org.hibernate.QueryException: could not resolve property: shop_id of: com.example.pizza.entity.Customer [SELECT p.productName, p.productPrice, p.customer.name, p.customer.address FROM com.example.pizza.entity.Purchase p INNER JOIN p.customer WHERE p.customer.shop_id = :shopId]

Purchase.java

package com.example.pizza.entity;

import java.time.LocalDateTime;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;

import lombok.Data;

@Entity
@Data
@Table(name="purchase")
public class Purchase {

    @Id
    @Column(name="purchase_id")
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long purchaseId;

    @ManyToOne
    @JoinColumn(name="shop_id")
    private Customer customer ;

    @Column(name="customer_id")
    private Long customerId;

    @Column(name="product_name")
    private String productName;

    @Column(name="product_price")
    private int productPrice;

    @Column(name="date")
    private LocalDateTime date;

    @Column(name="flag")
    private boolean flag;

}

Customer.java

package com.example.pizza.entity;

import java.util.List;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import javax.persistence.Table;

import lombok.Data;

@Entity
@Data
@Table(name="customer")
public class Customer {

    @Id
    @Column(name="customer_id")
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long customerId;

    @Column(name="shop_id")
    private Long shopId;

    @OneToMany(mappedBy = "customer", cascade = CascadeType.ALL)
    private List<Purchase> purchase;

    @Column(name="name")
    private String name;

    @Column(name="phone")
    private String phone;

    @Column(name="address")
    private String address;

}

PurchaseRepository.java

package com.example.pizza.repository;

import java.util.List;

import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;

import com.example.pizza.entity.Purchase;

@Repository
public interface PurchaseRepository extends JpaRepository<Purchase, Long>{
    @Query("SELECT p FROM Purchase p WHERE p.shopId = :shopId")
    List<Purchase> findPurchases(@Param("shopId")Long shopId);

    @Query("SELECT p.productName, p.productPrice, p.customer.name, p.customer.address"
    +" FROM Purchase p INNER JOIN p.customer WHERE p.customer.shop_id = :shopId")
    List<Purchase> findPandC(@Param("shopId") Long shopId);
}

テーブル定義

purchaseテーブル
イメージ説明
customerテーブル
イメージ説明

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

check解決した方法

0

customerテーブルのcustomer_idとpurchaseテーブルのcustomer_idでJOINすべきでした。
色々と組みなおさなければいけないので、こちらの質問は解決済みとさせていただきます。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

   @Query("SELECT p.productName, p.productPrice, p.customer.name, p.customer.address"
    +" FROM Purchase p INNER JOIN p.customer WHERE p.customer.shop_id = :shopId")

p.customerって何でしょう?
純粋に定義だけ見るなら INNER JOIN customer WHERE customer.shop_id = :shopId
ではないでしょうか。

あとはテーブル定義次第ですが。

ひとまず、アプリケーションから実行する前に、直に実行して想定の結果を得られるSQLを組めてから汲みこまれた方が良いと思います。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/09/11 17:43

    Purchase.javaのcustomerです。
    https://qiita.com/wataru908/items/f30332d48917c38220d5
    こちらの記事によると、Spring Bootでテーブル結合する場合このような記述方法になるみたいです。

    失礼しました、テーブル定義の方も追加致します。

    キャンセル

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

  • ただいまの回答率 87.48%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る