Android Room - 多对多关系不返回关联实体
创始人
2024-08-15 09:30:09
0

要在Android Room中实现多对多关系并排除关联实体的返回,可以使用中间表来解决。以下是一个示例:

首先,创建三个实体类:UserGroupUserGroup

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

@Entity
public class Group {
    @PrimaryKey
    public int id;
    public String name;
}

@Entity(primaryKeys = {"userId", "groupId"})
public class UserGroup {
    public int userId;
    public int groupId;
}

然后,创建一个 DAO 接口,用于定义查询方法。

@Dao
public interface UserGroupDao {
    @Insert
    void insert(UserGroup userGroup);

    @Delete
    void delete(UserGroup userGroup);

    @Query("SELECT * FROM `User` INNER JOIN UserGroup ON `User`.id = UserGroup.userId WHERE UserGroup.groupId = :groupId")
    List getUsersInGroup(int groupId);

    @Query("SELECT * FROM `Group` INNER JOIN UserGroup ON `Group`.id = UserGroup.groupId WHERE UserGroup.userId = :userId")
    List getGroupsForUser(int userId);
}

最后,在数据库类中定义实体和 DAO 的抽象方法。

@Database(entities = {User.class, Group.class, UserGroup.class}, version = 1)
public abstract class AppDatabase extends RoomDatabase {
    public abstract UserDao userDao();
    public abstract GroupDao groupDao();
    public abstract UserGroupDao userGroupDao();
}

现在,你可以通过 UserGroupDao 来访问多对多关系的数据,而不返回关联实体。

UserGroupDao userGroupDao = db.userGroupDao();

// 添加用户到组
UserGroup userGroup = new UserGroup();
userGroup.userId = 1;
userGroup.groupId = 1;
userGroupDao.insert(userGroup);

// 获取组中的用户
List usersInGroup = userGroupDao.getUsersInGroup(1);

// 获取用户所在的组
List groupsForUser = userGroupDao.getGroupsForUser(1);

通过这种方法,你可以在 Android Room 中实现多对多关系,并且可以根据需要排除关联实体的返回。

相关内容

热门资讯

揭秘真相!微扑克ai辅助器苹果... 揭秘真相!微扑克ai辅助器苹果版,雀神外挂怎么开,微信上微乐麻将是不是有挂呀(有挂技巧)在进入微信上...
重大消息!governorof... 重大消息!governorofpoker3有挂,红河全民雀神有挂吗,天天爱掼蛋辅助(有挂介绍);1、...
必知教程!微扑克ai机器人,七... 必知教程!微扑克ai机器人,七彩云南游戏辅助器,流年众娱有挂吗(有挂解密)1)七彩云南游戏辅助器辅助...
重大通报!微扑克真的有挂,雀神... 重大通报!微扑克真的有挂,雀神小程序辅助app下载,财神13张牌的规律(有挂插件);1、玩家可以在财...
最新通报!wepoke软件机器... 最新通报!wepoke软件机器人,广东雀神小程序老是输,上海哈灵辅助器免费(有挂插件)上海哈灵辅助器...
查到实测辅助!德州全自动辅助,... 查到实测辅助!德州全自动辅助,雀神小程序辅助app,山西扣点点外挂是不是真的(有挂脚本)小薇(透视辅...
科技分享!wepoke辅助真的... 科技分享!wepoke辅助真的,广东雀神辅助插件如何下载,白金岛跑得快辅助器(有挂插件)1、操作简单...
三分钟了解!wpk真的有挂,广... 三分钟了解!wpk真的有挂,广东雀神免费智能辅助下载,杭州都莱游戏有外 挂吗(有挂辅助)1、起透看视...
我来向大家传授!wpk德州伙牌... 我来向大家传授!wpk德州伙牌打法,雀神广东麻雀辅助器,蜜瓜大厅辅助怎么买(有挂介绍)1、蜜瓜大厅辅...
六分钟了解!红龙扑克机制,雀神... 六分钟了解!红龙扑克机制,雀神广东麻将输赢规律讲解,哈糖大菠萝(有挂脚本)1、构建自己的哈糖大菠萝辅...