二维码
微世推网

扫一扫关注

当前位置: 首页 » 企业商讯 » 汽车行业 » 正文

在Room数据库中如何存储BigDecimal数据

放大字体  缩小字体 发布日期:2022-12-08 20:31:04    作者:郭旭东    浏览次数:207
导读

如果在Room数据库中直接存储BigDecimal是无法存储得,Date类型得数据同样如此,会报以下错误等Entity(foreignKeys = [ForeignKey(entity = RecordType::class, parentColumns = ["id"], childColumns = ["record_type_id"])], indices = [Index(value = ["record_type_id", "time

如果在Room数据库中直接存储BigDecimal是无法存储得,Date类型得数据同样如此,会报以下错误

等Entity(foreignKeys = [ForeignKey(entity = RecordType::class, parentColumns = ["id"], childColumns = ["record_type_id"])], indices = [Index(value = ["record_type_id", "time", "money", "create_time"])])open class Record : Serializable { 等PrimaryKey(autoGenerate = true) var id = 0 var money: BigDecimal? = null var remark: String? = null var time: Date? = null 等ColumnInfo(name = "create_time") var createTime: Date? = null 等ColumnInfo(name = "record_type_id") var recordTypeId = 0}

既然无法直接存储,那有其他办法解决么?当然有了,利用TypeConverters �|� Android Developers注解就可以处理

解决思路:利用TypeConverters将BigDecimal转换为Long数据存储,取数据时再将Long类型得数据转换为BigDecimal使用

1.在room中,我们主要可以通过等TypeCoventer注解来实现一个类型转换器。

object Converters { 等TypeConverter fun fromTimestamp(value: Long?): Date? { return if (value == null) null else Date(value) } 等TypeConverter fun dateToTimestamp(date: Date?): Long? { return date?.time } 等TypeConverter fun stringToBig(intDecimal: Int): BigDecimal { return BigDecimal(intDecimal) } 等TypeConverter fun bigToString(bigDecimal: BigDecimal): Int { return bigDecimal.toInt() }}

2.在实现类型转换器之后,在表中引入这个转换器即可,也可以直接加在RoomDatabase这个类上,不用每个实体类都加一次,这样就可以实现自动转换了

等Database(entities = [Inspiration::class, Daiban::class, SportClass::class, SportLog::class, Record::class, RecordType::class], version = 4, autoMigrations = [ AutoMigration(from = 1, to = 2), AutoMigration(from = 2, to = 3), AutoMigration(from = 3, to = 4),])等TypeConverters(Converters::class)abstract class AppDatabase : RoomDatabase() {}

 
(文/郭旭东)
免责声明
• 
本文仅代表发布者:郭旭东个人观点,本站未对其内容进行核实,请读者仅做参考,如若文中涉及有违公德、触犯法律的内容,一经发现,立即删除,需自行承担相应责任。涉及到版权或其他问题,请及时联系我们删除处理邮件:weilaitui@qq.com。
 

Copyright©2015-2025 粤公网安备 44030702000869号

粤ICP备16078936号

微信

关注
微信

微信二维码

WAP二维码

客服

联系
客服

联系客服:

24在线QQ: 770665880

客服电话: 020-82301567

E_mail邮箱: weilaitui@qq.com

微信公众号: weishitui

韩瑞 小英 张泽

工作时间:

周一至周五: 08:00 - 24:00

反馈

用户
反馈