在最近开发的安卓项目中,有使用到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()方法加载数据。