如何使用 Android Room 创建具有两个或更多外键的 table?
How to create a table with a two or more foreign keys using Android Room?
根据entity-relationship model, the relationship between tbl_post
and tbl_category
could be specified using Room Persistency Library如下:
@Entity(foreignKeys = @ForeignKey(
entity = TblPost.class,
parentColumns = "id",
childColumns = "tbl_post_id")
)
class TblPostCategory {
@PrimaryKey
public String id;
@ColumnInfo(name = "user_id")
public String postId;
}
但是 TblPostCategory
依赖于两个外键:post_id
和 category_id
来自 TblPost
和 TbCategory
.
应如何使用 Room 注释描述关系?
TblCategory.java
@Entity
class TblCategory {
@PrimaryKey
@ColumnInfo(name="cat_id")
public String id;
@ColumnInfo(name = "cat_name")
public String name;
}
TblPost.java(缺少外键引用,但对案例来说并不重要)
@Entity
class TblPost {
@PrimaryKey
@ColumnInfo(name="post_id")
public String id;
public String title, content, create_time, author_id;
}
TblPostCategory.java
@Entity(foreignKeys = {
@ForeignKey(
entity = TblPost.class,
parentColumns = "post_id",
childColumns = "tbl_post_id"
),
@ForeignKey(
entity = TblCategory.class,
parentColumns = "cat_id",
childColumns = "tbl_category_id"
)
})
class TblPostCategory {
@PrimaryKey
@ColumnInfo(name="tbl_post_id")
public String id;
@ColumnInfo(name = "tbl_category_id")
public String categoryId;
}
在 Kotlin 中:
@Entity(
tableName = "some_table",
indices = [Index("id"), Index("brand_id"), Index("model_id")],
foreignKeys = [
ForeignKey(entity = BrandEntity::class, parentColumns = ["id"],
childColumns = ["brand_id"]),
ForeignKey(entity = ModelEntity::class, parentColumns = ["id"],
childColumns = ["model_id"]),
ForeignKey(entity = Table1Entity::class, parentColumns = ["id"],
childColumns = ["table1_id"]),
ForeignKey(entity = Table2Entity::class, parentColumns = ["id"],
childColumns = ["table2_id"])
]
)
根据entity-relationship model, the relationship between tbl_post
and tbl_category
could be specified using Room Persistency Library如下:
@Entity(foreignKeys = @ForeignKey(
entity = TblPost.class,
parentColumns = "id",
childColumns = "tbl_post_id")
)
class TblPostCategory {
@PrimaryKey
public String id;
@ColumnInfo(name = "user_id")
public String postId;
}
但是 TblPostCategory
依赖于两个外键:post_id
和 category_id
来自 TblPost
和 TbCategory
.
应如何使用 Room 注释描述关系?
TblCategory.java
@Entity
class TblCategory {
@PrimaryKey
@ColumnInfo(name="cat_id")
public String id;
@ColumnInfo(name = "cat_name")
public String name;
}
TblPost.java(缺少外键引用,但对案例来说并不重要)
@Entity
class TblPost {
@PrimaryKey
@ColumnInfo(name="post_id")
public String id;
public String title, content, create_time, author_id;
}
TblPostCategory.java
@Entity(foreignKeys = {
@ForeignKey(
entity = TblPost.class,
parentColumns = "post_id",
childColumns = "tbl_post_id"
),
@ForeignKey(
entity = TblCategory.class,
parentColumns = "cat_id",
childColumns = "tbl_category_id"
)
})
class TblPostCategory {
@PrimaryKey
@ColumnInfo(name="tbl_post_id")
public String id;
@ColumnInfo(name = "tbl_category_id")
public String categoryId;
}
在 Kotlin 中:
@Entity(
tableName = "some_table",
indices = [Index("id"), Index("brand_id"), Index("model_id")],
foreignKeys = [
ForeignKey(entity = BrandEntity::class, parentColumns = ["id"],
childColumns = ["brand_id"]),
ForeignKey(entity = ModelEntity::class, parentColumns = ["id"],
childColumns = ["model_id"]),
ForeignKey(entity = Table1Entity::class, parentColumns = ["id"],
childColumns = ["table1_id"]),
ForeignKey(entity = Table2Entity::class, parentColumns = ["id"],
childColumns = ["table2_id"])
]
)