0

我找不到关于这种关系的任何信息(一切都是关于一对一、一对多或多对多)。甚至那些对于我需要的东西来说看起来也有点太复杂了。

我有一张带有任务的表格和一张带有图像的表格。多个任务可以有相同的图像以节省空间(删除任务时不会删除图像)。我有一个任务的实体

import android.graphics.Bitmap
import androidx.room.*

@Entity(tableName = "tasks")
class Task(
    @PrimaryKey(autoGenerate = true)
    val id: Long,

    val imageId: Long = 0,

    // this needs a foreign key to Image
    val image: Image
)

另一个用于图像

import androidx.room.ColumnInfo
import androidx.room.PrimaryKey

@Entity(tableName = "images")
class Image (
    @PrimaryKey(autoGenerate = true)
    val id: Long,

    val title: String,
    @ColumnInfo(typeAffinity = ColumnInfo.BLOB)
    val data: ByteArray? = null
)

如何foreignKeyimageId列添加 a 以使其指向 a Image?我可以直接获取一个Image对象作为其成员,Task而无需创建另一个类吗?

4

2 回答 2

2

你必须在这里使用一对多的关系。d.android.com有一个例子。如果您这样做,您将拥有一个 Task 实体、一个 Image 实体和数据类 TaskWithImage,就像在提供的示例中一样。

于 2020-09-10T09:16:15.217 回答
0
data class TaskWithImage(
    @Embedded val task: Task,
    @Embedded(prefix = "img_") val image: Image
)

@Query("""
    SELECT * FROM tasks
    INNER JOIN images as img_ ON tasks.id = img_.id
""")
fun getTasksWithImage(): List<TaskWithImage>
于 2020-11-19T16:48:01.377 回答