kotlin学习整理笔记(1)

这篇博客主要记录了在Android开发中使用Kotlin操作SQLite数据库的经验。涉及数据类型,特别是INTEGER、TEXT和BLOB的亲和性,时间类型的转换利用TypeConverter注解,以及如何创建数据bean和使用@Entity、@PrimaryKey等注解。在将本地SQLite数据库文件导入Room数据库时,提到了createFromAsset()方法的应用。
摘要由CSDN通过智能技术生成

        在最近开发的安卓项目中,有使用到room数据库。具体的使用是导入assets文件夹中的数据库(xx.db)文件,xx.db文件是SQLite的数据库。对于xx.db文件的查看和修改可以使用SQLiteStudio工具。在使用的时候遇到的问题,特意记录下来。

1.关于数据类型

        SQLite数据库数据类型主要有5种。NULL:值是一个 NULL 值。INTEGER:值是一个带符号的整数。REAL:值是一个浮点值。TEXT:值是一个文本字符串,使用数据库编码(UTF-8、UTF-16BE 或 UTF-16LE)存储。BLOB:值是一个 blob 数据,完全根据它的输入存储。其中有关于亲和性(Affinity)的描述,通过我自己的测试,INTEGER是3,TEXT是2,BLOB是4,其他的没有测试。

2.时间类型

        由于SQLite的数据类型没有时间的类型,而时间的类型是存储在INTEGER或者TEXT中,所以在使用的时候,可以使用TypeConverter注解去转换,这个在使用的时候,在方法上使用@TypeConverter注解,在具体使用的地方使用的是@TypeConverters注解,注意不同的地方。

3.bean的创建

        在项目中,对应的数据表需要创建对应的数据bean,在kotlin中我创建的如图所示。使用@Entity注解对应的表名(表名与数据库中的要一致);定义对应的属性,使用@PrimaryKey注解主键,使用@ColumnInfo()注解可以重新定义属性名;此外,还要注意数据库中非空这个要对应,Boolean值属性,数据库显示的有可能是Integer要注意分辨。(由于SQLite中使用0、1代表trueh和false)

 4.读取的方式

        读取本地数据到room数据库中,首先需要创建room数据库,使用createFromAsset()方法加载数据。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值