android - 将 POJO 添加到 Room 数据库表中
问题描述
我有一个 POJO 类,我想将它作为我的实体OfflineDataRequestInfo
的一部分插入到数据库表中。OfflineData
但我得到一个错误
请问我该如何解决这个问题
error: Cannot figure out how to save this field into database. You can consider adding a type converter for it. private final com.i6systems.offlineservicelibrary.offlineDatabase.OfflineDataRequestInfo requestInfoJsonX = null;
这是我的代码
data class OfflineDataRequestInfo (
val status: String,
val userId: String,
val fuelOrderId: String,
val timeStamp: String,
val fuelOrder: String
)
@Entity
data class OfflineData (
@PrimaryKey(autoGenerate = true) val uid: Int = 0,
@ColumnInfo(name = "request_info_json") val requestInfoJson: String?,
@ColumnInfo(name="request_code") val requestCode: String?,
@ColumnInfo(name="request_info_jsonX") val requestInfoJsonX: OfflineDataRequestInfo
)
这不是我插入的
suspend fun insertOfflineData(requestInfoJson: String, requestCode: String, offlineDataRequestInfo: OfflineDataRequestInfo): Long {
var result: Long = 0
result = OfflineDatabaseManager.getInstance(app.applicationContext).insertOfflineData(
OfflineData(
0,
requestInfoJson,
requestCode,
offlineDataRequestInfo
))
return result
}
offlineHelper.insertOfflineData(
inPositionApiData.toString(),
"notifyInPosition",
OfflineDataRequestInfo(
"in-position",
action.userId,
id,
action.timestamp.toString(),
fuelOrderData.toString()
))
解决方案
如我所见,您有两种解决方法:
TypeConverter
为你的对象写一个OfflineDataRequestInfo
- 添加注释
@Embedded
@Embedded
@ColumnInfo(name="request_info_jsonX")
val requestInfoJsonX: OfflineDataRequestInfo
推荐阅读
- excel - 通过vba将excel中的word文件保存为pdf
- node.js - 使用代理时,运算符的 Rxjs 不发出值
- python - Jupyter Notebook 不导入任何模块
- c++ - 我似乎无法将指针分配给数组,然后更改数组的内容
- javascript - 来自 vue-i18n 的全局方法 this.$t 在函数中不起作用
- sql - 为什么我的 SQL 选择查询只返回一行?
- javascript - slate.js 示例中的以下代码片段在做什么?
- mysql - 在Netbeans中使用JSF,项目运行时不会加载css
- html - 在 Laravel pdf 中从 Javascript 到 HTML 获取价值
- vba - 您可以将 LongLong 存储在 Variant 中吗?