一尘不染

使用Like和%%运算符的Hibernate命名查询?

hibernate

在我的Hibernate JPA示例代码中。

public List<AttendeesVO> addAttendees(String searchKeyword) {
    TypedQuery<AttendeesVO> query = entityManager.createQuery(" select at from AttendeesVO at where at.user.firstName LIKE :searchKeyword",AttendeesVO.class);
    query.setParameter("searchKeyword", searchKeyword+"%");
    return query.getResultList();
}

给整个字符串时它工作正常 firstName=Narasimham

但是,当我们赋予Narasimhamie an

其实我的想法是我给Like运算符,% %使它可以工作给定字符串的任何字符。


阅读 241

收藏
2020-06-20

共1个答案

一尘不染

您正在使用 query.setParameter("searchKeyword", searchKeyword+"%");

代替 query.setParameter("searchKeyword", "%"+searchKeyword+"%");

第一个将返回Narasimham N Na Nar Nara等的行。

2020-06-20