我正在创建一个实体(房间持久性库)类Food,在那里我想使foodId作为自增量。

@Entity
class Food(var foodName: String, var foodDesc: String, var protein: Double, var carbs: Double, var fat: Double)
{
    @PrimaryKey
    var foodId: Int = 0
    var calories: Double = 0.toDouble()
}

如何设置foodId自增字段?


当前回答

例如,如果你有一个用户实体,你想存储,字段(姓,姓,电子邮件),你想自动生成id,你这样做。

@Entity(tableName = "users")
data class Users(
   @PrimaryKey(autoGenerate = true)
   val id: Long,
   val firstname: String,
   val lastname: String,
   val email: String
)

然后,Room将自动生成并自动增加id字段。

其他回答

您需要使用autoGenerate属性

你的主键注释应该像这样:

@PrimaryKey(autoGenerate = true)

参考主键。

用下面的代码注释你的Entity类。

在Java中:

@PrimaryKey(autoGenerate = true)
private int id;

在芬兰湾的科特林:

@PrimaryKey(autoGenerate = true)
var id: Int

然后,Room将自动生成并自动增加id字段。

@Entity(tableName = "user")
data class User(

@PrimaryKey(autoGenerate = true)  var id: Int?,
       var name: String,
       var dob: String,
       var address: String,
       var gender: String
)
{
    constructor():this(null,
        "","","","")
}

添加@PrimaryKey(autoGenerate = true)

@Entity
public class User {

    @PrimaryKey(autoGenerate = true)
    private int id;

    @ColumnInfo(name = "full_name")
    private String name;

    @ColumnInfo(name = "phone")
    private String phone;

    public User(){
    }

    //type-1
    public User(String name, String phone) {
        this.name = name;
        this.phone = phone;
    }

    //type-2
    public User(int id, String name, String phone) {
        this.id = id;
        this.name = name;
        this.phone = phone;
    }

}

存储数据时

 //type-1
 db.userDao().InsertAll(new User(sName,sPhone)); 

 //type-2
 db.userDao().InsertAll(new User(0,sName,sPhone)); 

1型 如果您不传递value为主键,默认情况下它将为0或 null。

2型

在创建对象(我的case user对象)时为id置空或零

如果字段类型为long或int(或其TypeConverter将其转换为long或int), Insert方法在插入项时将0视为未设置。

如果字段的类型是Integer或Long (Object)(或者它的TypeConverter将其转换为Integer或Long), Insert方法在插入项时将null视为未设置。

例如,如果你有一个用户实体,你想存储,字段(姓,姓,电子邮件),你想自动生成id,你这样做。

@Entity(tableName = "users")
data class Users(
   @PrimaryKey(autoGenerate = true)
   val id: Long,
   val firstname: String,
   val lastname: String,
   val email: String
)

然后,Room将自动生成并自动增加id字段。