我可以在房间中将非主键字段作为自动生成的值吗

Rak*_*i s 5 sqlite android android-database android-room

我有带有复合主键的表。我可以将其中一个文件设为自动生成吗?

Secenario :我有一个teacher table包含字段 techerId、姓名、性别、角色、部门、等级的字段,它具有由角色、部门和等级组成的复合主 ID。如何使teacherid自动生成?

ank*_*ag2 5

如果你仔细阅读这个答案,你会发现我们不能在复合主键中拥有自增属性。因此,解决方法是使用indexingand 的概念unique constraint。使role, deptt,grade列像您一样indices并将unique约束设置为true。这将确保这三个值对始终是唯一的(如primaryKey)。然后在实体中添加techerIdas Primarykey(autoGenerate = true)。你的entity班级看起来像:

@Entity(tableName = "teacher",indices = arrayOf(Index(value = ["role","department","grade"],unique = true)))
public class Teacher{
    @PrimaryKey(autoGenerate = true)
    int teacher_id;

    @ColumnInfo(name = "name")
    String teacher_name;

    //Rest of the fields
    ......
    ......
}
Run Code Online (Sandbox Code Playgroud)