Hibernate - 为INNER JOIN查询

时间:2018-05-25 16:45:14

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

(这是我的域名的简化版本)

我有一个实体Product,它与Connection的关系为1对N。映射工作正常,因此当我需要检索产品的连接时,我只需product.getConnections();

我需要与遗留系统的GUI集成,这需要我以这种格式生成列表:

|PRODUCT_ID|NAME|CONNECTION_ID|NAME|
|1|Product A|10|Connection A|
|1|Product A|11|Connection B|
|1|Product A|12|Connection C|

这基本上是此查询的结果:

SELECT *
FROM Product P
INNER JOIN Connection C ON C.PRODUCT_ID = P.PRODUCT_ID

我想在Product实体上创建一个可以使用连接名称填充的属性,以便我可以在我的服务上重用现有逻辑。我尝试使用@Formula,但这不起作用。似乎我可以通过创建一个Projection别名来实现这一点,但我没有成功。

我们使用Hibernate的CriteriaProjection API来执行查询。

Criteria productCriteria = session.createCriteria(Product.class);
ProjectionList columns = Projections.projectionList();

columns.add(Projections.property("productId"));
columns.add(Projections.property("name"));
columns.add(Projections.property("connectionName")); // How to make this work?
productCriteria.setProjection(columns);

List<Product> prodList = productCriteria.list();

这些是我的实体:

class Product {
    private Long productId;
    private String name;

    @OneToMany(mappedBy = "product")
    private List<Connection> connections;

    // How to get this populated?
    @Transient 
    private String connectionName;


}

class Connection {
    private Long connectionId;
    @Column(name = "PRODUCT_ID")
    private Long productId;
    private String name;

    @ManyToOne
    @JoinColumn(name = "PRODUCT_ID", insertable = false, updatable = false)
    private Product product;

}

1 个答案:

答案 0 :(得分:0)

idead是创建连接表的标准;尝试类似的事情:

Criteria productCriteria = session.createCriteria(Product.class);
Criteria connectionCriteria  = criteria.createCriteria("connections", "c", CriteriaSpecification.INNER_JOIN);

ProjectionList columns = Projections.projectionList();

columns.add(Projections.property("productId"));
columns.add(Projections.property("name"));
columns.add(Projections.property(connectionCriteria.getAlias() + ".connectionId"));
columns.add(Projections.property(connectionCriteria.getAlias() + ".name"));

productCriteria.setProjection(columns);

List<Product> prodList = productCriteria.list();