我有一个标准的长场

 @PrimaryKey(autoGenerate = true)
 val id:Long

但是它填充在过程中并且具有随机值。如果我尝试通过DAO将其添加到数据库中,则id不会被autoGenerate sqlite引擎覆盖
 @Insert(onConflict = OnConflictStrategy.REPLACE)
 fun insert(i:MyTypeObject)

如果我将此类型字段设为可为空,则它也无法正常工作
 @PrimaryKey(autoGenerate = true)
 val id:Long?

有一种方法可以将ID字段中的任何值都强制转换为db中的自动增量值?

我从存储库livedata中检索数据。在 View 模型中
private val db = CurrencyDatabase.getInstance(getApplication())
private val dao = db!!.nalDao()
private val service = Executors.newFixedThreadPool(1)

  fun addBook(book: CurrencyItem)
{
    service.submit {
        dao.insert(book)
    }
}

最佳答案

谢谢大家的帮助。通过官方文件“如果字段类型为long或int(或其TypeConverter将其转换为long或int),则插入方法在插入项目时将0设置为未设置。”您必须使用自动增量将0添加到id字段。

另外我的问题是对数据库数据文件的不正确访问。我在Androidstuidi®上使用“设备文件浏览器”,并在右键菜单上使用“另存为”。 SQL数据调试的错误方法。正确访问其adb终端 shell 的数据。例如,我的操作系统Win10和数据库文件名= book.db,数据表= nal

打开终端

cd %USERPROFILE%\AppData\Local\Android\sdk\platform-tools
adb root
adb devices

我的设备是“emulator-5554”
adb -s emulator-5554 shell
sqlite3

内壳
.open /data/data/com.example.scotland/databases/book.db
select * from nal;

如果找不到数据库文件。尝试打开
View->ToolWindows->Device File explorer.

有树您的ADB文件系统。你必须打开
data->data->YouProjectName->databases

10-04 22:59