質問

で短:冬眠をサポートしていない見通しで検索できる。この記事:

このコードです:

User usr = new User();
usr.setCity = 'TEST';
getCurrentSession().createCriteria(User.class)
.setProjection( Projections.distinct( Projections.projectionList()
.add( Projections.property("name"), "name")
.add( Projections.property("city"), "city")))
.add( Example.create(usr))

などのその他のポスターと、生成されたsqlの保有するクラスの参照だけで y0_=?の代わりにthis_.都市.

またアプローチおよび検索の問題追跡システムが見つかりなことがありますか?

もの利用が試みられましたが、投エイリアスとトランスが動作しない:

User usr = new User();
usr.setCity = 'TEST';
getCurrentSession().createCriteria(User.class)
.setProjection( Projections.distinct( Projections.projectionList()
.add( Projections.property("name"), "name")
.add( Projections.property("city"), "city")))
.add( Example.create(usr)).setResultTransformer(Transformers.aliasToBean(User.class));

での使用を予見しで検索できる。

役に立ちましたか?

解決

こちらをご確認ください。ユーザー。これは単な使用に制限します。と思いますか制限がこれまでとは大きく違う"日本における比例っていました。nullの場合分野の取得は無視されるデフォルト事例が)。

getCurrentSession().createCriteria(User.class)
.setProjection( Projections.distinct( Projections.projectionList()
.add( Projections.property("name"), "name")
.add( Projections.property("city"), "city")))
.add( Restrictions.eq("city", "TEST")))
.setResultTransformer(Transformers.aliasToBean(User.class))
.list();

こんにalaistToBeanもんです。できるだけループ以上の結果..

List<Object> rows = criteria.list();
for(Object r: rows){
  Object[] row = (Object[]) r;
  Type t = ((<Type>) row[0]);
}

いまでは手動での移植ユーザー自身ですることができてうれしいです。

そのような困難になり診断の問題です。

他のヒント

この問題のようなときの別名と同じ名前の物件です。Hibernateのようにエイリアスで使用することがsql.この文書化 こちらのこちらの, だと思っているとなるバグを修正Hibernateが、私には、Hibernateのチーム同意します。

もしかしたら、思った簡単な作業周辺のこの作品は私た。燃費は変更になる場合がございます。の詳細は以下のページをご覧下さいたの簡素化のためのコードにこの試料で会員の方はログインしてくだ他の誤りや誤植の:

Criteria criteria = session.createCriteria(MyClass.class)
    .setProjection(Projections.projectionList()
        .add(Projections.property("sectionHeader"), "sectionHeader")
        .add(Projections.property("subSectionHeader"), "subSectionHeader")
        .add(Projections.property("sectionNumber"), "sectionNumber"))
    .add(Restrictions.ilike("sectionHeader", sectionHeaderVar)) // <- Problem!
    .setResultTransformer(Transformers.aliasToBean(MyDTO.class));

を製造するこsql:

select
    this_.SECTION_HEADER as y1_,
    this_.SUB_SECTION_HEADER as y2_,
    this_.SECTION_NUMBER as y3_,
from
    MY_TABLE this_ 
where
    ( lower(y1_) like ? ) 

したがエラー: java.sql.SQLException:オーラ-00904:"Y1_":無効な識別子

ただ、私は、規制の使用このような:

Criteria criteria = session.createCriteria(MyClass.class)
    .setProjection(Projections.projectionList()
        .add(Projections.property("sectionHeader"), "sectionHeader")
        .add(Projections.property("subSectionHeader"), "subSectionHeader")
        .add(Projections.property("sectionNumber"), "sectionNumber"))
    .add(Restrictions.ilike("this.sectionHeader", sectionHeaderVar)) // <- Problem Solved!
    .setResultTransformer(Transformers.aliasToBean(MyDTO.class));

では次のようなsqlは、私の問題を解決した。

select
    this_.SECTION_HEADER as y1_,
    this_.SUB_SECTION_HEADER as y2_,
    this_.SECTION_NUMBER as y3_,
from
    MY_TABLE this_ 
where
    ( lower(this_.SECTION_HEADER) like ? ) 

私がい!Aイラストはピアプロの修正に痛い問題です。わからないこの修正ると言っても良いと思い、クエリーによる例題です。

現実の問題はバグがあることにhibernateで選択リストのエイリアスの場句:

http://opensource.atlassian.com/projects/hibernate/browse/HHH-817

もう土地はここを探し回答は、席のチケットとなります。また5年間で固定が理論的にしていただけることでしょう一つの次にリリースしていおります。

私は同じよ問題です。私が使っているクエリーによる例という結果によるカスタム。アプリケーションでいいようなもの:

select pageNo, abs(pageNo - 434) as diff
from relA
where year = 2009
order by diff

この作品の順序により提供しています。かんちゃって

Criteria crit = getSession().createCriteria(Entity.class);
crit.add(exampleObject);
ProjectionList pl = Projections.projectionList();
pl.add( Projections.property("id") );
pl.add(Projections.sqlProjection("abs(`pageNo`-"+pageNo+") as diff", new String[] {"diff"}, types ));
crit.setProjection(pl);

しかし追加

crit.addOrder(Order.asc("diff"));

を取得します org.hibernate.QueryException:を解決できない物件:diff ます。回避策と この なります。

PS:私が見つからない精巧な書類の利用にQBEのために、Hibernateにあたっては、全社員が上記は主に試行錯誤のアプローチ

ProjectionList pl = Projections.projectionList();
pl.add(Projections.property("id"));
pl.add(Projections.sqlProjection("abs(`pageNo`-" + pageNo + ") as diff", new String[] {"diff"}, types ), diff); ---- solution
crit.addOrder(Order.asc("diff"));
crit.setProjection(pl);

ないんだと思うし、何ができるかを見つの単語をする人が多くなっています。"の原因になhibernateないなどの制限は、そのクエリをつけるとともに、ものすべての記録の一覧表も掲載しています。約hibernateのバグが報告など、これは構文なのでしょうかを報告して固定が完全に失敗したダウンロード端子を装備。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top