如何编写Spring Data JPA存储库&实体连接两个表和where子句有多个条件

时间:2018-01-03 20:29:57

标签: hibernate jpa spring-boot spring-data-jpa hibernate-criteria

我可以在Spring Data JPA中使用@OneToOne使用主键关系加入两个实体Employee和Department并获得结果,但我不知道如何将where子句应用于我的要求。以下是查询

select * from 
  Employee e1,
  Department d1
Where e1.emp_id = d1.dep_id
  And d1.crtn_time between to_date('08-NOV-2017 00:00', 'DD-MON-YYYY hh24:mi') 
  And to_date('08-NOV-2017 20:00', 'DD-MON-YYYY hh24:mi')
  And e1.EMP_CODE='10' and e1.Desg='Clerk'

我能够得到结果直到这个条件,其中e1.emp_id = d1.dep_id,如下图所示,两个实体使用一对一映射的代码。

存储库:

@Transactional(readOnly = true, transactionManager = "empDataTxnManager")
public interface EmpRepository extends JpaRepository<Employee, Long> {
}

员工:实体

@Entity
@Table(name = "Employee")
public class Employee {

    @Id
    @Column(name = "emp_id")
    private Integer id;
    @Column(name = "Emp_Code")
    private String empCode;
    @Column(name = "Desg")
    private String desg;

    @OneToOne(fetch=FetchType.LAZY,
            cascade=CascadeType.ALL, 
            mappedBy="emp")
    private Department department;

    ---- getters & setters omitted

部门实体

@Entity
@Table(name = "Department")
public class Department {
    @Id
    @Column(name = "dep_id")
    private Integer id;
    @Column(name = "crtn_time")
    private String crtnTime;

    @OneToOne(fetch=FetchType.LAZY)
    @JoinColumn(name = "emp_id")
    private Employee emp;

    ----getters & setters omitted

我的问题是如何在Repository类的where子句之后应用其余的'AND'条件。像在Repository或Service类中编写的任何QueryByMethod(或)Criteria一样。

如何获得给定查询的完整结果。

我提到了spring数据jpa文档,但我无法找到确切的解决方案。

请建议是否有任何现有示例参考此要求

由于

1 个答案:

答案 0 :(得分:0)

您可以在存储库中执行以下操作:

public class YourRepo extends Serializable{
...
   public List<Entity> findEntities( Type parameter ) {
        List<Entity> resultList = new ArrayList<Entity>();
        Entity e;
        String sqlQuery = buildDynamicQuery(); // Build your complex where
        TypedQuery<Object[]> q = getEntityManager().createNamedQuery( sqlQuery , Object[].class ); //Extract custom info from both tables.
        q.setParameter( "parameterName", parameter );

        for ( Object[] element : q.getResultList() ) {
            e= new Entity();
            e.setAtribute1( elemento[0].toString() );
            e.setAtribute2( elemento[1].toString() );
            e.setAtribute3( elemento[3].toString() );
            resultList .add(e);
        }
        return resultList;
    }
}

private String buildDynamicQuery( HistoricoGIDFiltro filtroBusqueda ) {
        String sqlQuery = "SELECT filed1, field2, field3 ... FROM Employee e1,
  Department d1 WHERE e1.emp_id = d1.dep_id ";
        if ( look if it has an employ code  ) {
            sqlQuery += " AND e1.EMP_CODE='10' ";
        }
        return sqlQuery;
    }
  

使用上面的代码,您可以创建自定义查询并提取自定义   来自不同表格的信息。