目录
1、SQLite数据库
目的:
保存重复数据&结构化数据
基本操作:
- 定义架构的协定
- 创建数据库
- 信息添加到数据库
- 从数据库读取信息
- 从数据库删除信息
- 更新数据库
- 保留数据库连接,一般Activity的onDestroy()中关闭数据库
缺点:
android.database.sqlite
软件包提供Android上使用数据库所需的API,但是API级别较低
- 没有针对原始SQL查询的编译时验证,耗时又易错
- 需要使用大量样本代码在SQL查询和数据对象之间转换
解决:
强烈建议使用Room持久性库作为抽象层访问SQLite数据库中信息
2、ROOM持久性库
目的:
将数据保存到本地数据库
在SQLite上提供一个抽象层,以便充分利用SQLite&流畅访问数据库
优点:
- 提供针对SQL查询的编译时验证
- 提供方便注释,可最大限度减少重复和容易出错的代码样板
- 简化数据库迁移路径
导入依赖:
讲下面依赖项添加到build.gradle文件
dependencies { val room_version = "2.6.1" implementation("androidx.room:room-runtime:$room_version") annotationProcessor("androidx.room:room-compiler:$room_version") // To use Kotlin annotation processing tool (kapt) kapt("androidx.room:room-compiler:$room_version") // To use Kotlin Symbol Processing (KSP) ksp("androidx.room:room-compiler:$room_version") // optional - Kotlin Extensions and Coroutines support for Room implementation("androidx.room:room-ktx:$room_version") // optional - RxJava2 support for Room implementation("androidx.room:room-rxjava2:$room_version") // optional - RxJava3 support for Room implementation("androidx.room:room-rxjava3:$room_version") // optional - Guava support for Room, including Optional and ListenableFuture implementation("androidx.room:room-guava:$room_version") // optional - Test helpers testImplementation("androidx.room:room-testing:$room_version") // optional - Paging 3 Integration implementation("androidx.room:room-paging:$room_version") }
主要组件:
- 数据库类(Database):用于保存数据库&外界访问数据库
- 数据实体(Entities):表
- 数据访问对象(Dao):提供数据库增删改查的方法
使用步骤:
a.定义数据实体
@Entity
data class User(
@PrimaryKey
val uid: Int,
@ColumnInfo(name = "first_name")
val firstName: String?
@ColumnInfo(name = "last_name")
val lastName: String?
)
b.定义数据访问对象(接口)
@Dao
interface UserDao {
@Query("SELECT * FROM user")
fun getAll(): List<User>
@Query("SELECT * FROM user WHERE uid IN (:userIds)")
fun loadAllByIds(userIds: IntArray): List<User>
@Query("SELECT * FROM user WHERE first_name LIKE :first AND " +
"last_name LIKE :last LIMIT 1")
fun findByName(first: String, last: String): User
@Insert
fun insertAll(vararg users: User)
@Delete
fun delete(user: User)
}
c.定义数据库类
- 带有@Database注解,注解相关联 数据实体
- 该类为抽象类,继承并扩展RoomDatabase
- 定义获取Dao类的抽象方法
@Database(entities = [User::class], version = 1)
abstract class AppDatabase : RoomDatabase() {
abstract fun userDao(): UserDao
}
d.实例化并操作数据库
val db = Room.databaseBuilder(
applicationContext,
AppDatabase::class.java, "database-name"
).build()
val userDao = db.userDao()
val users: List<User> = userDao.getAll()