我使用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);