我正在使用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();
我只获取Retailer表本身的内容,但是我还需要Shop实体值为null。只有在我致电getShops()
后,实体才会被填满。我需要在第一个查询时填写实体。怎么做?
感谢。
答案 0 :(得分:0)
使用queryDeep方法:
return mDaoSession.getRetailerDao().queryDeep(null);