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

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

詳細はこちら
Spring Security

Spring Securityは、Springのサブプロジェクトの一つでWebアプリケーションに必要な機能を追加します。正規ユーザーであるかを確認するための「認証機能」と、ユーザーのアクセスを制御する「認可機能」を簡単に追加することが可能です。

Java

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Spring

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

Spring Boot

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

Q&A

解決済

1回答

4180閲覧

Spring Data JPAの@queryアノテーションを使用するとEntityクラスの@Columnが効かなくなる

syachiku

総合スコア117

Spring Security

Spring Securityは、Springのサブプロジェクトの一つでWebアプリケーションに必要な機能を追加します。正規ユーザーであるかを確認するための「認証機能」と、ユーザーのアクセスを制御する「認可機能」を簡単に追加することが可能です。

Java

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Spring

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

Spring Boot

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

0グッド

0クリップ

投稿2021/02/16 11:12

前提・実現したいこと

SpringBoot2とSpring Data JPAを使用したウェブアプリケーション作成の勉強をしています。
データベースはH2のインメモリでの動作を想定しています。

今実現したいことはログイン周りの処理で
1.入力されたメアドとパスワードを元にusersテーブルからログインユーザの情報を取得
2.ログインユーザ情報内のユーザIDを元にuser_rolesテーブルから権限のリストを取得
3.権限リストの権限IDを元にrolesテーブルから権限名を取得
以上のような処理を行いたいです。

そこで上記2.と3.の部分についてはテーブルの結合を行い一度のSQL発行で処理しようと考えました。

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

JPAの@queryアノテーションで発行するSQLを設定したところEntityクラスで設定した@Columnアノテーションが効かなくなってしまい?
プロパティが解決できないというエラーが発生します。

Entityクラスのフィールド名をテーブルカラム名と同じ(アンダーバー付き)にしたところエラーが発生しなくなりましたが
後々別の問題の種になりそうなので解決策をご教示ください。

Caused by: org.hibernate.QueryException: could not resolve property: user_id of: com.xxxxxxx.yyy.entity.UserRoles [SELECT T1, T2 FROM com.xxxxxxx.yyy.entity.UserRoles T1 INNER JOIN com.xxxxxxx.yyy.entity.Roles T2 ON T1.role_id = T2.id WHERE T1.user_id = :userId] at org.hibernate.QueryException.generateQueryException(QueryException.java:120) ~[hibernate-core-5.4.27.Final.jar:5.4.27.Final] at org.hibernate.QueryException.wrapWithQueryString(QueryException.java:103) ~[hibernate-core-5.4.27.Final.jar:5.4.27.Final] at org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:220) ~[hibernate-core-5.4.27.Final.jar:5.4.27.Final] at org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:144) ~[hibernate-core-5.4.27.Final.jar:5.4.27.Final] at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:113) ~[hibernate-core-5.4.27.Final.jar:5.4.27.Final] at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:73) ~[hibernate-core-5.4.27.Final.jar:5.4.27.Final] at org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:162) ~[hibernate-core-5.4.27.Final.jar:5.4.27.Final] at org.hibernate.internal.AbstractSharedSessionContract.getQueryPlan(AbstractSharedSessionContract.java:604) ~[hibernate-core-5.4.27.Final.jar:5.4.27.Final] at org.hibernate.internal.AbstractSharedSessionContract.createQuery(AbstractSharedSessionContract.java:716) ~[hibernate-core-5.4.27.Final.jar:5.4.27.Final] ... 68 common frames omitted

該当のソースコード

Java

1@Table(name = "user_roles") 2@Entity 3public class UserRoles implements Serializable { 4 @Getter @Setter 5 @Id 6 @GeneratedValue(strategy = GenerationType.IDENTITY) 7 private Long id; 8 9 @Getter @Setter 10 @Column(name = "user_id") 11 private Long userId; 12 13 @Getter @Setter 14 @Column(name = "role_id") 15 private Long roleId; 16 17 @Getter @Setter 18 private String roleName; 19 20 21 @Getter @Setter 22 @ManyToOne 23 @JoinColumn(name = "role_id", insertable = false, updatable = false) 24 private Roles roles; 25}

Java

1@Table(name = "roles") 2@Entity 3public class Roles implements Serializable { 4 @Getter @Setter 5 @Id 6 @GeneratedValue(strategy = GenerationType.IDENTITY) 7 private Long id; 8 9 @Getter @Setter 10 private String roleName; 11 12 13 @Getter @Setter 14 @OneToMany(mappedBy = "roles", cascade = CascadeType.ALL) 15 private List<UserRoles> userRoles; 16}

Java

1public interface UserRolesRepository extends JpaRepository<UserRoles, Long> { 2 @Query( 3 "SELECT T1, T2 FROM UserRoles T1" 4 + " INNER JOIN Roles T2" 5 + " ON T1.role_id = T2.id" 6 + " WHERE T1.user_id = :userId" 7 ) 8 List<UserRoles> find(@Param("userId") Long userId); 9}

試したこと

Entityクラスのフィールド名をテーブルカラム名と同じ(アンダーバー付き)にしたところエラーが発生しなくなりました。

補足情報(FW/ツールのバージョンなど)

SpringBoot2.4.2

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

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

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

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

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

guest

回答1

0

ベストアンサー

すみませんが、質問を熟読せずに勘で回答します。違ってたらスルーしてください。

@Queryアノテーションに書くクエリーは、デフォルトでは、素のSQL構文ではなく、JPQL構文として解釈されます。なので、カラム名を書いてるつもりなのに、クラスのフィールド名として解釈されてるのではないでしょうか。

素のSQLとして解釈させたい場合は、@Query(value = "SELECT ... FROM ...", nativeQuery = true)のように書いてみてください。

投稿2021/02/16 15:16

gpsoft

総合スコア1323

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問