前提・実現したいこと
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
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。