这是示例 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.id
pet.userId
类别列表"