当前位置: 首页 > news >正文

Android Room 使用模版

 

文章目录

  • 一、配置依赖
    plugins {id 'kotlin-kapt'
    }android {compileOptions {sourceCompatibility JavaVersion.VERSION_17targetCompatibility JavaVersion.VERSION_17}kotlinOptions {jvmTarget = '17'}
    }dependencies {implementation("androidx.room:room-runtime:2.4.2")kapt("androidx.room:room-compiler:2.4.2")
    }
  • 二、标记实体类
    @Entity(tableName = "banner")
    data class Banner(val desc: String,@PrimaryKeyval id: Int,val imagePath: String,val isVisible: Int,val order: Int,val title: String,val type: Int,val url: String
    )

  • 三、封装工具类
    object RoomUtil {@Volatileprivate var mDataBase: MyDataBase? = nullfun getInstance(context: Context): MyDataBase {if (mDataBase == null) {synchronized(this) {if (mDataBase == null) {mDataBase = Room.databaseBuilder(context, MyDataBase::class.java, "my_database").allowMainThreadQueries().build()}}}return mDataBase!!}@Database(entities = [Banner::class], version = 1)abstract class MyDataBase : RoomDatabase() {abstract fun bannerDao(): BannerDao}@Daointerface BannerDao {@Query("SELECT * FROM banner")fun getBanners(): List<Banner>@Query("SELECT * FROM banner WHERE id = :userId")fun getBannerById(userId: Int): Banner?@Insert(onConflict = OnConflictStrategy.REPLACE) //重复时则会替换fun insert(user: Banner)@Deletefun delete(user: Banner)@Updatefun update(user: Banner)}
    }

  • 四、使用
    data.forEach {RoomUtil.getInstance(this@WelcomeActivity).bannerDao().insert(it)}val banner = RoomUtil.getInstance(this@WelcomeActivity).bannerDao().getBanners()[0]RoomUtil.getInstance(this@WelcomeActivity).bannerDao().delete(banner)
    RoomUtil.getInstance(this@WelcomeActivity).bannerDao().getBanners()
    RoomUtil.getInstance(this@WelcomeActivity).bannerDao().getBannerById(banner.id)

http://www.lryc.cn/news/354047.html

相关文章:

  • Linux/Ubuntu 中安装 ZeroTier,实现内网穿透,2分钟搞定
  • java技术:oauth2协议
  • Java 18 新特性详解
  • 【css3】06-css3新特性之网页布局篇
  • 【开源】大学生竞赛管理系统 JAVA+Vue+SpringBoot+MySQL
  • 跨境选品师不是神话:普通人也能轻松掌握,开启全球贸易新篇章!
  • 前缀和,差分算法理解
  • ubuntu/部分docker容器无法访问https站点
  • 【MySQL】库的基础操作
  • 嵌入式0基础开始学习 ⅠC语言(2)运算符与表达式
  • 汇编语言(一)
  • 2010-2022年各省新质生产力数据(含原始数据+测算代码+计算结果)
  • 需求分析部分图形工具
  • ML307R OpenCPU GPIO使用
  • python基于深度学习的聊天机器人设计
  • Golang设计模式(四):观察者模式
  • huggingface 笔记:查看GPU占用情况
  • JavaSE 学习记录
  • HTML与CSS的学习
  • 【单片机】STM32F070F6P6 开发指南(一)STM32建立HAL工程
  • 源码编译安装Rsync数据同步
  • SQL Server2019安装步骤教程(图文)_最新教程
  • 【SpringBoot】SpringBoot中防止接口重复提交(单机环境和分布式环境)
  • 零基础学Java(全170集)
  • 摄像头应用测试
  • Golang框架HTTP客户端框架zdpgo_resty发送表单请求
  • 【机器学习300问】99、多通道卷积神经网络在卷积操作时有哪些注意事项?
  • Rust之函数、单元测试
  • Linux环境下TensorFlow安装教程
  • 基于Open3D的点云处理19-模拟生成点云