如何解决如何使用like运算符编写jpql查询
select e.emp_id,e.emp_name
from emp e
left outer join dept on e.dept_id = d.dept_id and upper(d.dept_name) like upper('%dev%')
我在下面尝试过它对我不起作用。我需要像关键字后如何用两个百分位和参数名称编写
@Query(value = "select e.emp_id,e.emp_name from emp e left outer join dept on e.dept_id= d.dept_id and upper(d.dept_name) like upper(%:deptName%),nativeQuery = true)
List<Employee> searchAllEmployees(@Param("deptName")String deptName);
解决方法
假设您有以下 Employee
实体:
@Entity
public class Employee
{
@Id
@Column(name = "emp_id")
Long id;
@Column(name = "emp_name")
String name;
@ManyToOne
@JoinColumn(name = "dept_id")
Department department;
}
@Entity
public class Department
{
@Id
@Column(name = "dept_id")
Long id;
@Column(name = "dept_name")
String name;
}
你可以写如下jpql:
@Query("select e from Employee e left join e.department d where upper(d.name) like '%' || upper(:deptName ) || '%'")
List<Employee> searchAllEmployees(@Param("deptName")String deptName);
另请参阅 hibernate 文档的 this 部分。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。