0

我被困在这里!任何帮助,将不胜感激。

我的情况是我的模块上有一个@OneToMany 关联。

 class Parent{
    @OneToMany(
       mappedBy="parent"
    )
    return List<Child> getChildren();
 }

 class Child{
   @ManyToOne
   return Parent getParent();
 }

在客户端我想得到整个对象图。

我这样做(以 DataGrid 作为显示的 AsyncDataProvider):

 requestContext.getParents().with("children").fire(new Receiver<CallbackProxy>() {
                @Override
                public void onSuccess(CallbackProxy response) {
                    display.setRowData(range.getStart(),response.getParents());
                    updateRowCount(response.getCount().intValue(), true);
                }
            });

我的 DAO 只是查询整个地图。

 Criteria criteria = session.createCriteria(Parent.class);
 criteria.setFetchMode("children", FetchMode.JOIN);
 criteria.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);

 /* we got all the map here on the server side */       

 Callback callback = new Callback();
 callback.setCount(count);
 callback.setParents(criteria.list());

 return callback;

但我不能得到孩子。它们的列表为空。请注意我正在使用 with("children")

谢谢你。

4

1 回答 1

0

RequestContext.getParents() 似乎返回 CallbackProxy 但不返回父级。所以 with 子句应该看起来像“parents.childs”。

顺便说一句,为什么不称他们为“孩子”?只是为了这种情况,GWT 家伙有一天会添加一个语法检查器:-)

于 2012-04-18T06:21:23.973 回答