在 Spring JPA @Query 中组合参数和硬编码子句
Combine parameters and hardcoded clauses in Spring JPA @Query
我在应用程序中有一个用户存储库,它非常适合这种情况:
@Query(" FROM UserEntity ue WHERE ue.site.id = :site_id
and ue.name = :username")
User findByUsername(@Param("site_id") String siteId,
@Param("username") String userName);
其中一个用户字段中现在有一个新选项,可以防止用户出现在应用程序的任何位置。因此,我没有修改整个应用程序,而是决定只修改存储库中带有硬编码子句的查询,如下所示:
@Query(" FROM UserEntity ue WHERE ue.site.id = :site_id
and ue.name = :username and ue.state != 'Disabled'")
User findByUsername(@Param("site_id") String siteId,
@Param("username") String userName);
(变化的部分是and ue.state != 'Disabled'
)
问题是,无论 state 的值是什么,这样的查询都不会 return 任何东西。
我也试过 ue.state not like 'Disabled'
,但结果相同。
我见过很多使用 @Query
的例子,但没有找到任何带有硬编码子句的例子。这可能吗?
是的,您可以在不更改方法签名的情况下传递硬编码值。
JPA 存储库
@Query(" FROM Users ue WHERE ue.userLogin = :userLogin and ue.userName != 'admin'")
public Users cehckeme(@Param("userLogin") String userLogin);
测试代码
ApplicationContext ctx = new ClassPathXmlApplicationContext(
"spring_model.xml");
usersRepository = (UsersRepository) ctx.getBean("usersRepository");
System.out.println(usersRepository.cehckeme("pthakre").getUserLogin());
生成的查询
Hibernate:
select
*
from
( select
users0_.USER_ID as USER1_2_,
users0_.USER_LOGIN as USER2_2_,
users0_.USER_NAME as USER3_2_,
users0_.USER_PASSWORD as USER4_2_
from
MED_USERS users0_
where
users0_.USER_LOGIN=?
and users0_.USER_NAME<>'admin' )
where
rownum <= ?
我在应用程序中有一个用户存储库,它非常适合这种情况:
@Query(" FROM UserEntity ue WHERE ue.site.id = :site_id
and ue.name = :username")
User findByUsername(@Param("site_id") String siteId,
@Param("username") String userName);
其中一个用户字段中现在有一个新选项,可以防止用户出现在应用程序的任何位置。因此,我没有修改整个应用程序,而是决定只修改存储库中带有硬编码子句的查询,如下所示:
@Query(" FROM UserEntity ue WHERE ue.site.id = :site_id
and ue.name = :username and ue.state != 'Disabled'")
User findByUsername(@Param("site_id") String siteId,
@Param("username") String userName);
(变化的部分是and ue.state != 'Disabled'
)
问题是,无论 state 的值是什么,这样的查询都不会 return 任何东西。
我也试过 ue.state not like 'Disabled'
,但结果相同。
我见过很多使用 @Query
的例子,但没有找到任何带有硬编码子句的例子。这可能吗?
是的,您可以在不更改方法签名的情况下传递硬编码值。
JPA 存储库
@Query(" FROM Users ue WHERE ue.userLogin = :userLogin and ue.userName != 'admin'")
public Users cehckeme(@Param("userLogin") String userLogin);
测试代码
ApplicationContext ctx = new ClassPathXmlApplicationContext(
"spring_model.xml");
usersRepository = (UsersRepository) ctx.getBean("usersRepository");
System.out.println(usersRepository.cehckeme("pthakre").getUserLogin());
生成的查询
Hibernate:
select
*
from
( select
users0_.USER_ID as USER1_2_,
users0_.USER_LOGIN as USER2_2_,
users0_.USER_NAME as USER3_2_,
users0_.USER_PASSWORD as USER4_2_
from
MED_USERS users0_
where
users0_.USER_LOGIN=?
and users0_.USER_NAME<>'admin' )
where
rownum <= ?