5

Ebeanを使用してPlay2アプリを作成しています。IDのリストによって会場を取得するためのメソッドを使用してサービスクラスを作成しました。

public static List<Venue> getVenuesForIds(List<Long> list){          
    ArrayList<Venue> venues = new ArrayList<Venue>();
    String sql = "select c.id, c.name from Company c where in (:ids)";
    List<SqlRow> sqlRows =
                Ebean.createSqlQuery(sql).setParameter("ids", list).findList();        
    for(SqlRow row : sqlRows) {
        venues.add(new Venue(row.getLong("id"), row.getString("name")));
    }        
    return venues;
}

しかし、私は得ています:

[PersistenceException: Query threw SQLException:You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'in (201639091,201637666)' at line 1 Query was: select c.id, c.name from Company c where in (?,?) ] 

http://www.avaje.org/ebean/introquery.htmlを読みましたが、おそらく正しい構文を見逃していました。これを生のSQLで実行したいと思います。私は何を逃しましたか?

4

2 に答える 2

3

あなたの要求は正しくないようです。

どうですか:

 "select c.id, c.name from Company c where c.id in (:ids)";
于 2012-12-10T15:16:45.807 に答える
3

このような「洗練された」クエリを実行する必要はありません。モデルでcommonFinder<I,T>を(1回)使用する場合は十分です。Venue

@Entity
@Table(name = "Company")
public class Venue extends Model {

    @Id
    public Long id;
    public String name;
    // other fields

    public static Finder<Long, Venue> find
            = new Finder<Long, Venue>(Long.class, Venue.class);
}

したがって、メソッド内の1行のコードで同じタスクを実行できます。

 public static List<Venue> getVenuesForIds(List<Long> ids){          
     return Venue.find.select("id,name").where().idIn(ids).findList();
 }

または同様の表現で:

 public static List<Venue> getVenuesForIds(List<Long> ids){          
     return Venue.find.select("id,name").where().in("id",ids).findList();
 }
于 2012-12-10T18:02:02.903 に答える