在Spring启动JPA中加入查询不相关的实体

时间:2016-12-15 03:05:56

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

我正在尝试在不相关的实体A和B

上编写如下的查询
Select a.x,a.y,a.z FROM A a ,B b Where
b.Parameter_Name='APPLICABLE_RULE_TYPE' And b.Parameter_KEY='MC' AND 
b.Parameter_Value=a.rule_type And a.Rule_Status='ON' Order By Rule_Priority;

我无法弄清楚应该如何在Spring启动应用程序的Repository类中编写它。

有人可以建议这样做吗

提前致谢。

编辑:

我已经尝试过像

这样的原生查询
@Query(value = "Select Rule_Id, Rule_Sql,S_System,S_Entity, s_table_name,Rule_Sql_Type "
        + "FROM rule_master TRM ,T_SYSTEM_CONFIG TSC  Where"
        + " Tsc.Parameter_Name='APPLICABLE_RULE_TYPE' "
        + " And Tsc.Parameter_KEY= :systemType"
        + " AND Tsc.Parameter_Value=trm.rule_type  "
        + " And Rule_Status='ON'"
        + " Order By Rule_Priority", nativeQuery = true)
public List<RuleMaster> findByRuleStatus(@Param("systemType" String systemType);

但是收到此错误

o.h.engine.jdbc.spi.SqlExceptionHelper   : SQL Error: 17006, SQLState: null
o.h.engine.jdbc.spi.SqlExceptionHelper   : Invalid column name
org.springframework.orm.jpa.JpaSystemException: could not execute query; nested exception is org.hibernate.exception.GenericJDBCException: could not execute query

1 个答案:

答案 0 :(得分:4)

我能够通过使用本机查询来解决这个问题。

错误是因为我只从表中选择了部分列。相反,我使用下面的查询工作正常:

@Query(value = "Select * "
    + "FROM rule_master TRM ,T_SYSTEM_CONFIG TSC  Where"
    + " Tsc.Parameter_Name='APPLICABLE_RULE_TYPE' "
    + " And Tsc.Parameter_KEY= :systemType"
    + " AND Tsc.Parameter_Value=trm.rule_type  "
    + " And Rule_Status='ON'"
    + " Order By Rule_Priority", nativeQuery = true)
public List<RuleMaster> findByRuleStatus(@Param("systemType" String systemType);