如果嵌入了子对象,则只能引用子对象的属性

时间:2012-09-05 19:44:23

标签: java google-app-engine jpa google-cloud-datastore datanucleus

我想通过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));

所有工作都很好。但我得到了实体,我宁愿和我的豆子一起工作。所以我试着这样做(Query是javax Query):

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.

我不明白这一点。我之间的关系似乎很好,因为如果我这样做:

stockEntity.getStockValues();

我正确获得stockValues。 为什么我的请求失败了?

感谢您的帮助

1 个答案:

答案 0 :(得分:3)

简而言之:在GAE中,您只能在一个实体类型中查询,或者在一个类中以JPA / JDO的说法进行查询。由于StockValueStock是两个独立的类,因此是两个独立的实体类型,因此无法跨越它们进行查询。

正如错误所暗示的那样:您可以通过@Embedded批注查询embedded one classes into another。在这种情况下,您将拥有两个类,但在数据存储区中只有一个实体类型。

另外:key.parentKey与实体关系无关。 “父”是GAE数据存储区中用于定义Entity Groups的概念,用于定义事务范围。