炎炎設(shè)計(jì)
2023-04-26 17:05:07
我有一個(gè)枚舉 (ClubRole),它有一個(gè)方法從這個(gè)枚舉返回值的集合。我嘗試使用 SpEl 從查詢內(nèi)部調(diào)用此方法。 @Query("select m from ClubMember m " + "where m.student = :student " + "and m.role in :#{#role.getParents()}" ) List<ClubMember> findByRoleWithInheritance(@Param("student") Student student, @Param("role") ClubRole role);這通過(guò)了構(gòu)建,并且應(yīng)用程序運(yùn)行但是當(dāng)調(diào)用此方法時(shí)我得到``沒(méi)有找到名稱角色的參數(shù)綁定!; 嵌套的異常是 java.lang.IllegalArgumentException:找不到名稱角色的參數(shù)綁定!我嘗試了不同的方法,但都沒(méi)有用。我想知道在這種情況下是否可以使用 SpEl,如果可以,如何使用?
1 回答

小怪獸愛(ài)吃肉
TA貢獻(xiàn)1852條經(jīng)驗(yàn) 獲得超1個(gè)贊
看起來(lái)這是 spring-data-jpa 中的一個(gè)問(wèn)題。我可以看到人們?cè)?spring-blog 上討論同樣的問(wèn)題。不確定是否存在未解決的問(wèn)題。您可以嘗試以下作為解決方法。
@Query("select m from ClubMember m " +
"where m.student = :#{#student}" +
"and m.role in :#{#role.getParents()}"
)
List<ClubMember> findByRoleWithInheritance(@Param("student") Student student, @Param("role") ClubRole role);
或者您可以嘗試對(duì)第二個(gè)參數(shù)進(jìn)行索引訪問(wèn),例如#{[1].getParents()}
這可能會(huì)有所幫助。
添加回答
舉報(bào)
0/150
提交
取消