我使用greendao,需要从几个类似于左连接函数的表中提取数据。下面是我的模式生成器的一个引用:

private static void genRetailers(Schema schema) {
    // create retailer entity
    Entity retailerEntity = schema.addEntity("Retailer");
    retailerEntity.addIdProperty().notNull();
    retailerEntity.addStringProperty("title");

    Entity shopEntity = schema.addEntity("Shop");
    shopEntity.addIdProperty().notNull();
    shopEntity.addStringProperty("address");
    Property retailerId = shopEntity.addLongProperty("retailerId")
            .getProperty();
    // (1) Retailer < - > (*) Shop
    retailerEntity.addToMany(shopEntity, retailerId);
}

当我这样做的时候:
    return (ArrayList<Retailer>) mDaoSession.getRetailerDao()
                .queryBuilder().list();

我只得到零售商表本身的内容,但是我还需要商店实体值,该值为空。只有在我调用getShops()之后,实体才会被填充。我需要在第一次查询时填充实体。怎么做的?
谢谢。

最佳答案

使用querydep方法:

return mDaoSession.getRetailerDao().queryDeep(null);

07-27 14:28