[英]Query method with Enum and JPA Repository
I have entity Driver and enum DriverLanguage.我有实体驱动程序和枚举驱动程序语言。 I want to get a list of drivers who can speak choosen language by parameter in repository method.
我想通过存储库方法中的参数获取可以说所选语言的驱动程序列表。
...
@Entity
public class Driver{
private Long id;
private firstName;
@ElementCollection(targetClass = DriverLanguage.class)
@Enumerated(EnumType.STRING)
@CollectionTable(name = "driver_language",
joinColumns = @JoinColumn(name = "driver_language_id"))
@Column(name = "driver_language")
private Set<DriverLanguage> languages = new HashSet<>();
}
public enum DriverLanguage {
ENGLISH,
GERMAN
}
Now I'm using @Query method.现在我正在使用@Query 方法。
My first approach:我的第一种方法:
@Repository
public interface DriverRepository extends JpaRepository<Driver, Long> {
@Query("SELECT d "
+ "FROM Driver d "
+ "JOIN DriverLanguage dl on d.id = dl.driver_language_id "
+ "WHERE dl.driver_language = ?1")
List<Driver> findByLanguage(String language);
}
ERROR: Caused by: org.hibernate.hql.internal.ast.QuerySyntaxException: Path expected for join!
Then I read that maybe I shouldn't use JOIN so I tried this:然后我读到也许我不应该使用 JOIN 所以我尝试了这个:
@Repository
public interface DriverRepository extends JpaRepository<Driver, Long> {
@Query("SELECT d "
+ "FROM Driver d, DriverLanguage dl "
+ "WHERE d.id = dl.driver_language_id AND dl.driver_language = ?1")
List<Driver> findByLanguage(String language);
}
ERROR: Caused by: org.hibernate.hql.internal.ast.QuerySyntaxException: DriverLanguage is not mapped
What I'm missing here?我在这里缺少什么?
The straightahead JPQL Query could be直接的 JPQL 查询可能是
@Repository
public interface DriverRepository extends JpaRepository<Driver, Long> {
@Query("SELECT d "
+ "FROM Driver d "
+ "WHERE ?1 MEMBER OF d.languages")
List<Driver> findByLanguage(DriverLanguage language);
}
The error messaegs are telling you:错误消息告诉您:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.