13

这是示例 POJO

@Entity
public class User {
  @PrimaryKey
  public String id;
}

@Entity
public class Pet {
  @PrimaryKey
  public String id;
  public String userId;
  public String petName;
}

@Entity
public class Category {
  @PrimaryKey
  public String id;
  public String petId;
  public String categoryName;
}

这是我的UsersWithPets类,用于获取所有用户和宠物。

public class UserWithPets {
  @Embedded
  public User user;
  @Relation(parentColumn = "id", entityColumn = "userId", entity =   Pet.class)
  public List<Pet> pets;
}

我的用户道

@Dao
public interface UserDao {
  @Query("SELECT * FROM User")
  List<UserWithPets> loadUsersWithPets();
}

和用户数据库

@Database(entities = {User.class, Pet.class, Category.class}, version = 1)
@TypeConverters(DateConverter.class)
public abstract class UsersDb extends RoomDatabase {

  private static UsersDb INSTANCE;

  public abstract UserDao userDao();

  public static UsersDb getInstance(Context context) {
      if (INSTANCE == null) {
          synchronized (UsersDb.class) {
              if (INSTANCE == null) {
                  INSTANCE = Room.databaseBuilder(context.getApplicationContext(), UsersDb.class,
                          "User.db")
                          .build();
              }
          }
      }
      return INSTANCE;
  }
}

UserWithPets ”嵌入用户对象并与“Pet”的关联列表相关但是如果我的“ Pet ”POJO 可以与“ Category ”有一对多关系,我如何获取“ Category ”列表。

此外,用户 DAO 通过映射和之间的 id 仅返回所有“用户”及其“列表<宠物>” 如果的“宠物”POJO 可以有许多“类别”(类别列表),我如何创建我的DAO 和抽象数据库类,这样查询特定的“用户”id 将返回“用户”对象及其“宠物列表”和包含“类别列表”的单个“宠物” ,查询所有将返回所有“用户列表”,其中每个用户包含一个“宠物列表”,每个宠物包含一个“user.idpet.userId类别列表"

4

2 回答 2

17

您需要将查询映射到像 PetWithCategories 这样的 POJO/Java Bean 类:

public class UserWithPets {
  @Embedded
  public User user;
  @Relation(parentColumn = "id", entityColumn = "userId", entity = Pet.class)
  public List<PetWithCategories> pets;
}

public class PetWithCategories {
  @Embedded
  public Pet pet;
  @Relation(parentColumn = "id", entityColumn = "petId")
  public List<Category> categories;
}
于 2017-10-17T08:04:13.930 回答
0

完成第一个请求后,启动其他数据库请求可能会更容易。我看不出有任何方法可以通过 @Relation 或内部连接来实现这一点,因为这不是您想要返回的单个值。你可以使用左连接,但这会给你多个宠物,只有不同的类别对象。

List<UserWithPets> list = userDao.loadUsersWithPets();
for(UserWithPets user : list) {
   for(Pet pet : user.pets) {
      pet.categories = categorieDao.getCategoriesByPetId(pet.id); 
      //pet.categories should have the @Ignore annotation
   }
}

...

@Dao
public interface CategoryDao {

   @Query("SELECT * FROM Category WHERE petId = :petId")
   List<Categories> getCategoriesByPetId(int petId);
}
于 2017-07-07T20:54:00.777 回答