Google AppEngine で datanucleus を使用して親キーでデータを取得したいと考えています。JPAを使用しています。
これが私の Stock Bean (親) です。
@Entity
public class Stock implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Key key;
@OneToMany(fetch=FetchType.LAZY, mappedBy="stock")
private List<StockValue> stockValues;
}
これが私の StockValue Bean (子) です。
@Entity
public class StockValue implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Key key;
@ManyToOne
private Stock stock;
}
私は次のようにリクエストを実行しようとしました (クエリは datanucleus クエリです):
DatastoreService datastoreService = DatastoreServiceFactory.getDatastoreService();
Query queryStock = new Query("Stock");
queryStock.addFilter("name", FilterOperator.EQUAL, "toto");
PreparedQuery prepare = datastoreService.prepare(queryStock);
Entity asSingleEntity = prepare.asSingleEntity();
Query query = Query("StockValue", asSingleEntity.getKey());
prepare = datastoreService.prepare(query);
List<Entity> asList = prepare.asList(FetchOptions.Builder.withLimit(10));
そして、すべてそれでうまくいきます。しかし、私はエンティティを取得し、自分の Bean を使用したいと考えています。だから私はこれをやろうとしました(クエリはjavaxクエリです):
Query createQuery = entityManager.createQuery("SELECT p FROM Stock p WHERE p.name = \"toto\"");
Object singleResult = createQuery.getSingleResult();
Stock stockEntity = (Stock)singleResult;
createQuery = entityManager.createQuery("SELECT p FROM StockValue p WHERE p.key IS NOT null AND p.key.parentKey = :parentKey ");
createQuery.setParameter(":parentKey", stockEntity.getKey());
Object singleResult2 = createQuery.getSingleResult();
そして、ここに私の問題があります、私はこのエラーを受け取ります:
org.datanucleus.store.appengine.FatalNucleusUserException: SELECT FROM StockValue p WHERE p.key IS NOT null AND p.key.parentKey = :parentKey: Can only reference properties of a sub-object if the sub-object is embedded.
私はこれを理解していません。Bean 間の関係は良好に思えます。これを行うと、次のようになります。
stockEntity.getStockValues();
私はstockValuesを正しく取得します。リクエストが失敗するのはなぜですか?
ご協力いただきありがとうございます