首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Spring @Query中的参数和硬编码子句组合

Spring @Query中的参数和硬编码子句组合
EN

Stack Overflow用户
提问于 2015-05-12 14:24:30
回答 1查看 5K关注 0票数 1

我在应用程序中有一个用户存储库,它可以很好地处理这种情况:

代码语言:javascript
复制
@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);

现在在其中一个用户字段中有一个新的选项,它应该防止用户出现在应用程序中的任何地方。因此,我没有修改整个应用程序,而是决定只使用硬编码子句修改存储库中的查询,如下所示:

代码语言:javascript
复制
@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')

问题是,无论状态的值如何,这种查询都不会返回任何内容。

我也尝试过ue.state not like 'Disabled',但结果是一样的。我见过很多使用@Query的例子,但是没有找到任何硬编码子句。这可能吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-05-12 15:03:18

是的,您可以在不更改方法签名的情况下传递硬编码值。

JPA存储库

代码语言:javascript
复制
@Query(" FROM Users ue WHERE ue.userLogin = :userLogin  and ue.userName != 'admin'")
public Users cehckeme(@Param("userLogin") String userLogin);

测试代码

代码语言:javascript
复制
ApplicationContext ctx = new ClassPathXmlApplicationContext(
                    "spring_model.xml");
usersRepository = (UsersRepository) ctx.getBean("usersRepository"); 
           System.out.println(usersRepository.cehckeme("pthakre").getUserLogin());

归属查询

代码语言:javascript
复制
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 <= ?
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30193790

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档