0

MySQL 5 DB を備えた WebSphere Application Server で OpenJPA 2.1 を使用しています。

日付のリストがあり、IN 演算子を使用して、DB の日付がリストにあるエントリのみを DB から取得したいと考えています。

List<Date> dates = new LinkedList<Date>();
dates.add(somedates);

私のクエリは次のようになります。

  List<Object> list = em
    .createNativeQuery(
        "SELECT w.date FROM week_table w WHERE w.date IN ?1")
        .setParameter(1, dates).getResultList();

しかし、ArgumentException: org.apache.openjpa.persistence.argumentexception the specified parameter of type is not a valid query parameter が発生します

Exception in thread "main" <openjpa-2.1.1-SNAPSHOT-r422266:1141200 nonfatal user error> org.apache.openjpa.persistence.ArgumentException:org.apache.openjpa.persistence.argumentexception the specified parameter of type "class java.util.LinkedList" is not a valid query parameter.
    at org.apache.openjpa.jdbc.sql.DBDictionary.setUnknown(DBDictionary.java:1426)
    at org.apache.openjpa.jdbc.kernel.SQLStoreQuery$SQLExecutor.executeQuery(SQLStoreQuery.java:218)
    at org.apache.openjpa.kernel.QueryImpl.execute(QueryImpl.java:1005)
    at org.apache.openjpa.kernel.QueryImpl.execute(QueryImpl.java:863)
    at org.apache.openjpa.kernel.QueryImpl.execute(QueryImpl.java:794)
    at org.apache.openjpa.kernel.DelegatingQuery.execute(DelegatingQuery.java:542)
    at org.apache.openjpa.persistence.QueryImpl.execute(QueryImpl.java:315)
    at org.apache.openjpa.persistence.QueryImpl.getResultList(QueryImpl.java:331)

リストまたはリスト値をクエリに渡すにはどうすればよいでしょうか。

宜しくお願いします

4

1 に答える 1

1

JPQL (非ネイティブ) クエリを使用してみてください。

于 2012-07-18T13:07:09.427 に答える