作者:mobiledu2502857723 | 来源:互联网 | 2023-01-20 10:41
在使用Room Persistence Library时,我发现没有方法可以使用NOT NULL和UNIQUE约束设置数据类字段.SQLite是否支持这些约束.迁移使用这些约束的旧数据库不是一个问题吗?任何人都可以就此问题提出建议吗?
1> CommonsWare..:
我开始知道没有方法可以使用NOT NULL和UNIQUE约束设置数据类字段
一@NonNull
对注释@Entity
字段将导致该领域的专栏已经NOT NULL
应用到它.
unique=true
on @Index
将强制执行唯一性约束(例如@Entity(indices={@Index(value="something", unique=true)}
).但是,您是正确的,UNIQUE
不支持列上的普通约束,而不是通过索引.
迁移使用这些约束的旧数据库不是一个问题吗?
Room不是为支持现有的数据库结构而设计的,特别是在现在的alpha
状态下.随着时间的推移,我希望Room能够支持更高比例的SQLite功能,但如果它达到100%,我会感到震惊.
koltin版本`@Entity(tableName =“ some_table”,index = [Index(value = [“ some_field”],unique = true)])`
2> Vincent Hiri..:
关于NOT NULL
使用Kotlin的人的补充答案:
请注意,将类型标记为非可选类型会自动使其不为null(而可选类型则不会这样做)。
您可以在@Database(exportSchema = true)
数据库中由room with生成的模式中对其进行检查。
例如,我有类似的东西:
@Entity(tableName = "messages")
data class Message (
@PrimaryKey
val messageId: UUID = UUID.randomUUID(),
val date: Date = Date(),
val receivedDate: Date? = null
)
在生成的模式中,我可以阅读:
"CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`messageId` TEXT NOT NULL, `date` INTEGER NOT NULL, `receivedDate` INTEGER, PRIMARY KEY(`messageId`))"
(注意:Int
由于我在其他地方使用了转换器,Date类型在此处为an ,UUID为字符串)