使用Hibernate属性Projection获取关联并将其注入Dto

时间:2013-07-07 13:45:27

标签: hibernate associations projection many-to-one

我有一个Entity(MediaCostRule),它有几个常规字段和一个用@ElementCollection注释的关联字段(MediaCostRuleSource)

我还有一个dto(MediaCostRuleDto),它包含实体字段的子集,并且还包含相同的关联集

这是类代码

@Entity
@Table(name = "media_cost_rules")
public class MediaCostRule extends AdminEntity{

@Id
@GeneratedValue
@Column(name = "media_cost_rule_id")
private Integer id;

@Column(name = "name")
@Length(max = 100)
private String name;

@Column(name="is_enabled")
private Boolean enabled;

@ManyToOne
@JoinColumn(name = "brand_id")
private Brand brand;

@ElementCollection(fetch = FetchType.EAGER)
@CollectionTable(name = "media_cost_rule_sources", joinColumns = @JoinColumn(name = "media_cost_rule_id"))
private Set<MediaCostRuleSource> mediaCostRuleSources = new HashSet<MediaCostRuleSource>();

=============================================== ======================

@Embeddable
public class MediaCostRuleSource {


@Column(name = "source_name")
private String sourceName;

@Column(name = "ordinal")
private Integer ordinal;

=============================================== ===================

public class MediaCostRuleDto extends AbstractAdminDto {


@Size(min = 1)
private Set<MediaCostRuleSource> mediaCostRuleSources = new HashSet<MediaCostRuleSource>();


@NotNull
private String name;

=============================================== ============================

现在我想要的是使用Projections来获取mediaCostRuleSources和我的实体的名称,并将它直接注入我的MediaCostRuleDto(使用AliasToBeanResultTransformer)。

我尝试过以下代码:

@Test
public void findByIdDirectTest2(){

    Criteria crit = sessionFactory.getCurrentSession().createCriteria(MediaCostRule.class).setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);

    ProjectionList projectionList = Projections.projectionList();
    projectionList.add(Projections.property("name").as("name"));
    projectionList.add(Projections.property("mediaCostRuleSources").as("mediaCostRuleSources"));
    crit.setProjection(projectionList);
    List list = crit.list();
}

但我总是得到异常(ArrayIndexOutOfBoundsException)

使用Hibernate

必须有某种方式来做这样的事情

你知道吗??

Yosi

1 个答案:

答案 0 :(得分:0)

你必须使用

crit.setFetchMode("mediaCostRuleSources",FetchMode.JOIN)