1

Spring WebFlow プロジェクトで、この休止状態の呼び出しに並べ替えを追加するにはどうすればよいですか。私は Spring Webflow プロジェクトに取り組んでおり、次の呼び出しで並べ替えを追加する必要があります。

@SuppressWarnings("unchecked")
    public List<School_lookupModel> getSelectableSchools(String b) {
        String myLike = b + "%";
        Session mySession = sessionFactory.getCurrentSession();
        List<School_lookupModel> mySchools = (List<School_lookupModel>) mySession
                .createCriteria(School_lookupModel.class)
                .add(Restrictions.like("school", myLike)).list();

        return mySchools;
    }

次のコードを試しましたが、ビルドされませんでした:

public List<School_lookupModel> getSelectableSchools(String b) {

        String myLike = b + "%";

        Session mySession = sessionFactory.getCurrentSession();

        List<School_lookupModel> mySchools = (List<School_lookupModel>) mySession
                .createCriteria(School_lookupModel.class)
            .add(Restrictions.like("school", myLike)
            .addOrder(Order.asc("school"))).list();


        return mySchools;
    }

誰かが注文を最初の呼び出しに追加する方法を教えてください..ありがとうビルドで次の2つのエラーが発生しています:

構文エラー、「)」を挿入して完了し、メソッド addOrder(Order) はタイプ SimpleExpression に対して定義されていません

これが私のクラスです:

package org.xxx.schoolvisit.model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.validation.constraints.Size;

import org.hibernate.annotations.OrderBy;

@Entity
@Table(name = "school")
public class School_lookupModel {

    @Override
    public String toString() {
        return "School_lookupModel [school=" + school + ", school_name="
                + school_name + ", region=" + region + ", district=" + district
                + ", getSchool()=" + getSchool() + ", getSchool_name()="
                + getSchool_name() + ", getRegion()=" + getRegion()
                + ", getDistrict()=" + getDistrict() + ", getClass()="
                + getClass() + ", hashCode()=" + hashCode() + ", toString()="
                + super.toString() + "]";
    }

    @Id
    @Column(name = "school")
    private String school; 

    @Column(name = "school_name")
    private String school_name; 

    @Column(name = "region")
    private String region; 

    @Column(name = "district")
    private String district;

    public String getSchool() {
        return school;
    }

    public void setSchool(String school) {
        this.school = school;
    }

    public String getSchool_name() {
        return school_name;
    }

    public void setSchool_name(String school_name) {
        this.school_name = school_name;
    }

    public String getRegion() {
        return region;
    }

    public void setRegion(String region) {
        this.region = region;
    }

    public String getDistrict() {
        return district;
    }

    public void setDistrict(String district) {
        this.district = district;
    } 


}
4

1 に答える 1

1

このレベルの括弧がありません

  .add(Restrictions.like("school", myLike)
  .addOrder(Order.asc("Name")).list();

このようにします

 .add(Restrictions.like("school", myLike)
  .addOrder(Order.asc("Name"))).list();

あなたが得ているエラーは何ですか?ここの例を見る: http://docs.jboss.org/hibernate/orm/3.3/reference/en/html/querycriteria.html 構文は正しいようです。O/R マッピングを使用する必要があります。クラスをテーブルまたはxmlファイルにマッピングするために注釈を使用していますか? 名前というフィールドがありますか、それとも名前または名前がありますか? これらを試しましたか?

于 2012-09-10T17:39:02.763 に答える