android room

 

注意点: 

1. gradle 中加入 'kotlin-kapt' 插件,  依赖加入  

implementation "androidx.work:work-runtime:2.2.0"
kapt "androidx.room:room-compiler:2.1.0"

2. 主activity 中用thread 执行。 

package com.example.testroom

import android.content.Context
import androidx.room.Database
import androidx.room.Room
import androidx.room.RoomDatabase
import androidx.room.migration.Migration
import androidx.sqlite.db.SupportSQLiteDatabase

@Database(version = 3, entities = [User::class], exportSchema = false)
abstract class AppDatabase : RoomDatabase() {

    abstract fun userDao(): UserDao

    companion object {
        private val MIGRATION_1_2 = object : Migration(1, 2) {
            override fun migrate(database: SupportSQLiteDatabase) {
                database.execSQL("create table Book (id integer primary key autoincrement not null, name text not null, pages integer not null)")
            }
        }

        private val MIGRATION_2_3 = object : Migration(2, 3) {
            override fun migrate(database: SupportSQLiteDatabase) {
                database.execSQL("alter table Book add column author text not null default 'unknown'")
            }
        }

        private var instance: AppDatabase? = null

        @Synchronized
        fun getDatabase(context: Context): AppDatabase {
            instance?.let {
                return it
            }
            return Room.databaseBuilder(context.applicationContext, AppDatabase::class.java, "app_database")
                .build().apply {
                instance = this
            }
        }
    }
}


package com.example.testroom

import android.text.Editable
import androidx.room.Entity
import androidx.room.PrimaryKey

@Entity
 data class User(var firstName: String, var lastName: String, var age: Int ) {

    @PrimaryKey(autoGenerate = true)
    var id: Long = 0
}



package com.example.testroom

import androidx.room.*

@Dao
interface UserDao {

    @Insert
    fun insertUser(user: User): Long

    @Update
    fun updateUser(newUser: User)

    @Query("select * from User")
    fun loadAllUsers(): List<User>

    @Query("select * from User where age > :age")
    fun loadUsersOlderThan(age: Int): List<User>

    @Delete
    fun deleteUser(user: User)

    @Query("delete from User where lastName = :lastName")
    fun deleteUserByLastName(lastName: String): Int

    @Query("delete from User where age = :age")
    fun deleteByAge(age: Int)

    @Query("delete  from User ")
    fun deleteAll()

}

package com.example.testroom

import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.util.Log
import kotlinx.android.synthetic.main.activity_main.*
import kotlin.concurrent.thread

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        val userDao = AppDatabase.getDatabase(this).userDao()

        add.setOnClickListener {
            val user = User(tv_name.text.toString() ,tv_name.text.toString(),tv_age.text.toString().toInt())
            thread {
                userDao.insertUser(user)
            }
        }

        clear.setOnClickListener {
            thread {
                userDao.deleteAll()
            }
        }
        get.setOnClickListener {
            thread {
                for (user in userDao.loadAllUsers()) {
                    Log.d("ddd", user.toString())
                }
            }
        }

        bt_deletebyage.setOnClickListener {
            thread {
                userDao.deleteByAge(tv_age.text.toString().toInt())
            }
        }
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值