【问题标题】:How do you order a oneToMany join table in hibernate criteria您如何在休眠条件中订购 oneToMany 连接表
【发布时间】:2011-07-30 10:09:46
【问题描述】:

假设我有一个类 Mother 与 Kittens 的 oneToMany 映射

@Entity
@org.hibernate.annotations.Entity(dynamicUpdate = true)
@Table(name = "Mother")

.....

@OneToMany(fetch = FetchType.LAZY, targetEntity=Kittens.class, cascade=CascadeType.ALL)
@JoinColumn(name="motherId")
private List<Kittens> kittens;

我正在使用标准 Api 来提供列表

Criteria criteria = this.getSession().createCriteria(Mother.class);
Criterion MotherType = Restrictions.eq("type", "domesticated");
criteria.add(MotherType)
.addOrder(Order.asc("motherName"))
.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY)
.setFetchMode("kittens", FetchMode.JOIN)
// .addOrder(Order.asc("kittens.kittenName"));
List test = criteria.list();

在我尝试添加小猫字段 kittenName 的顺序之前工作正常

我还尝试在 Kitten @OneToMany(...etc ) 下添加 @OrderBy(value="kittenName") 注释,在您使用标准 API 之前它工作正常,并且此订单将在任何其他订单语句之前sql。

提前欢呼任何帮助...

【问题讨论】:

    标签: hibernate criteria


    【解决方案1】:

    您需要将@javax.persistence.OrderBy 注释添加到您的kittens 列表中。

    @OneToMany(fetch = FetchType.LAZY,
               targetEntity=Kittens.class,
               cascade=CascadeType.ALL)
    @JoinColumn(name="motherId")
    @OrderBy("kittenName")
    private List<Kittens> kittens;
    

    @见

    【讨论】:

    • 嗨拉尔夫。我已经尝试过了,但是生成的 sql 将 kittenName 顺序放在 MotherName 顺序之前。即选择...按kittens.kittenName asc、mother.motherName asc 排序。而且我正在尝试按mother.motherName asc,kittens.kittenName asc 来实现订单。谢谢
    • @user456147:我好像不太明白你想做什么?加载什么,按什么顺序?什么不能按你的意愿工作?
    • 抱歉,如果我没有说清楚。我想按 MotherName 然后 KittenName 订购。如果我将 OrderBy 放在 Kitten 实体上,则顺序相反。
    • @user456147:“我想先按 MotherName 再按 KittenName。”? - 你的意思是,“我想按妈妈的名字订购小猫”?
    • 嗨,拉尔夫最终使用了 criteria.createAlias("genres", "genreAlias", CriteriaSpecification.INNER_JOIN) 而不是 setFetchMode(... SELECT) 你允许我按照你在你的建议中设置顺序用@OrderBy 回答。干杯。
    猜你喜欢
    • 2017-07-30
    • 1970-01-01
    • 1970-01-01
    • 2010-11-21
    • 1970-01-01
    • 2017-09-25
    • 2011-01-07
    • 1970-01-01
    • 2012-10-05
    相关资源
    最近更新 更多