kotlin中使用Room数据库

本文详述了在Kotlin项目中使用Room数据库进行增删改查及排序的步骤。首先介绍了环境搭建,包括创建Kotlin项目、配置build.gradle、导入依赖。接着创建了Application、Student和Teacher实体类以及对应的Dao接口。在 Dao 中,注意到insert方法的注解差异,该注解决定了数据插入时的行为。在实际操作中,展示了如何在Activity中进行数据的插入、查询、更新和删除,并对Teacher表进行了排序和更新操作,解释了注解对于数据替换的影响。
摘要由CSDN通过智能技术生成

最近在kotlin环境下,写了一个room数据库的demo,各种情况跑了一下,在此总结一下。

涉及情况:增、删、改、查、排序

1、环境搭建
1.1、Android Studio下,新建一个kotlin项目,
1.2、去app的build.gradle中进行一些配置
顶部增加

apply plugin: 'kotlin-kapt'

然后

defaultConfig {
        ......
        javaCompileOptions {
            annotationProcessorOptions {
                arguments = ["room.schemaLocation":
                                     "$projectDir/schemas".toString()]
            }
        }
}

1.3、导入依赖

implementation 'android.arch.persistence.room:runtime:1.1.1'
kapt 'android.arch.persistence.room:compiler:1.1.1'

2、创建一个Application,用于提供全局上下文

class MyApplication : Application() {

    companion object {

        var instance: MyApplication by Delegates.notNull()

        fun instance() = instance
    }

    override fun onCreate() {
        super.onCreate()

        instance = this
    }

}

3、分别创建Student和Teacher(我写了2张表)

import android.arch.persistence.room.ColumnInfo
import android.arch.persistence.room.Entity
import android.arch.persistence.room.PrimaryKey

@Entity(tableName = "Student")
data class Student(

    @PrimaryKey(autoGenerate = true)
    var studentID: Int?,
    @ColumnInfo(name = "s_name")
    var studentName: String?,
    @ColumnInfo(name = "s_type")
    var studentType: String?

)
import android.arch.persistence.room.ColumnInfo
import android.arch.persistence.room.Entity
import android.arch.persistence.room.PrimaryKey

@Entity(tableName = "Teacher")
data class Teacher(

    @PrimaryKey(autoGenerate = true)
    var teacherID: Int?,
    @ColumnInfo(name = "t_name")
    var teacherName: String?,
    //教学年限
    @ColumnInfo(name = "t_year")
    var teachYear: Int?

)

4、与之对应的,分别创建StudentDao和TeacherDao

import android.arch.persistence.room.*

@Dao
interface BaseDao<T> {

    @Insert(onConflict = OnConfl
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值