我有一个标准的长场
@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