微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Android机房:自动查询代码,无需检查完整性

如何解决Android机房:自动查询代码,无需检查完整性

此问题是Room - Using external SQLites as well as internal DB的集成。 在我的应用程序中,我使用的是下载的数据库,这意味着,从理论上讲,我不知道表方案是否发生变化,它可以有一个带有3列的“ User”表,下一个有4列的表是旧的3与一个新的,不受android应用程序管理。 我想使用Android房间来避免编写繁琐的查询,并使用繁琐的阅读代码将其写在课堂上。 因此,我尝试编写一个数据类,例如:

@Entity
data class User(
    val id :Integer,val name :String,val surname :String )
@Dao
public interface UserDao {
    @Query("SELECT * FROM User where id=:id")
    fun getUser(id :Integer) :User?
}
@Database(entities = [User::class],exportSchema = false,version=1)
abstract class DownloadedDatabase : RoomDatabase() {
    abstract fun userDao(): UserDao
}

fun test(context :Context,downloadedFile:String,id:Integer) : User? {
    val db= Room.databaseBuilder(context,DownloadedDatabase::class.java,downloadedFile).build()
    return db.userDao().getUser(id)
}

用户表实际上有4列,所以当我尝试使用它时,抛出了java.lang.IllegalStateException: Pre-packaged database has an invalid schema,因为它看到数据库表有4列而不是3列,但是我不能将新列添加用户类中,因为在下一版本中,我可以再增加一个第五栏。

我必须将其编写为sqliteOpenHelper吗?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。