Android Room嵌入关系忽略了WHERE条件。
创始人
2024-08-15 12:30:43
0

要解决Android Room嵌入关系忽略WHERE条件的问题,可以按照以下步骤进行:

  1. 确保在定义实体类和关系时正确设置了FOREIGN KEY和关系注解。

示例代码:

@Entity(tableName = "user")
public class User {
    @PrimaryKey
    public int id;

    public String name;
}

@Entity(tableName = "post", foreignKeys = @ForeignKey(entity = User.class, parentColumns = "id", childColumns = "userId", onDelete = ForeignKey.CASCADE))
public class Post {
    @PrimaryKey
    public int id;

    public String title;

    @ColumnInfo(name = "userId")
    public int userId;
}

public class UserWithPosts {
    @Embedded
    public User user;

    @Relation(parentColumn = "id", entityColumn = "userId", entity = Post.class)
    public List posts;
}
  1. 确保在查询时使用了适当的WHERE条件。

示例代码:

@Dao
public interface UserDao {
    @Transaction
    @Query("SELECT * FROM user WHERE id = :userId")
    LiveData getUserWithPosts(int userId);
}
  1. 如果仍然存在问题,可以尝试使用INNER JOIN来手动执行嵌入查询,并使用WHERE条件筛选结果。

示例代码:

@Dao
public interface UserDao {
    @Transaction
    @Query("SELECT * FROM user INNER JOIN post ON user.id = post.userId WHERE user.id = :userId")
    LiveData getUserWithPosts(int userId);
}

通过按照上述步骤操作,您应该能够解决Android Room嵌入关系忽略WHERE条件的问题。确保在定义实体类和关系时正确设置FOREIGN KEY和关系注解,并在查询时使用适当的WHERE条件。如果问题仍然存在,可以尝试使用INNER JOIN来手动执行嵌入查询并使用WHERE条件筛选结果。

相关内容

热门资讯

透视解迷!uupoker有透视... 透视解迷!uupoker有透视吗(透视)德普之星透视,教程妙招(有挂教学)-哔哩哔哩1、透视解迷!u...
透视开挂!wepokerplu... 透视开挂!wepokerplus透视脚本免费(透视)德普辅助软件,教程手册(真实有挂)-哔哩哔哩1、...
透视解谜!德普之星辅助器app... 透视解谜!德普之星辅助器app(透视)拱趴大菠萝开挂方法,教程技法(证实有挂)-哔哩哔哩1)拱趴大菠...
透视解迷!pokerrrr2辅... 透视解迷!pokerrrr2辅助(透视)哈糖大菠萝攻略,教程方案(有挂秘诀)-哔哩哔哩1、哈糖大菠萝...
透视解谜!WePoKer辅助器... 透视解谜!WePoKer辅助器(透视)wepoker私人局俱乐部辅助,教程积累(有挂规律)-哔哩哔哩...
透视开挂!sohoo竞技联盟辅... 透视开挂!sohoo竞技联盟辅助器(透视)德州局透视脚本免费版下载手机版,教程妙计(有挂神器)-哔哩...
透视揭幕!aapoker能控制... 透视揭幕!aapoker能控制牌吗(透视)epoker底牌透视,教程资料(确实有挂)-哔哩哔哩1、玩...
透视分享!wepoker有辅助... 您好,wepoker有辅助器吗这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054...
透视推荐!wepoker软件辅... 透视推荐!wepoker软件辅助程序(透视)wepoker软件辅助程序,教程烘培(有挂解密)-哔哩哔...
透视科普!hhpoker是正规... 透视科普!hhpoker是正规的吗(透视)hhpoker辅助器视频,教程窍要(详细教程)-哔哩哔哩1...