Android Room+RxJava实现数据添加和查询(二)

2020年已经过去10多天了,过年的气氛也越来越浓了,最近工作似乎不是以前那么忙碌了,大家都忙着回家了。

最近开发了一款阅读器,需要用到的是本地存储。我参照了谷歌官方文档先是大概浏览了一下Room是如何进行数据的增加、查询、修改和删除的。

Room 官方文档介绍的功能点:使用 Room 实体定义数据、定义对象之间的关系、在数据库中创建视图、在数据库中创建视图、预填充数据库、迁移数据库、测试和调试数据库、引用复杂数据等。话不多说了,今天我要实现的是用Room配合RxJava实现数据的添加和查询。

一、添加依赖文件:

dependencies {

def room_version = “2.2.2”

implementation “androidx.room:room-runtime:$room_version”

annotationProcessor “androidx.room:room-compiler:$room_version”

// optional - RxJava support for Room

implementation “androidx.room:room-rxjava2:$room_version”

def rxandroidVersion = “2.1.1”

implementation “io.reactivex.rxjava2:rxandroid:$rxandroidVersion”

}

二、创建项目结构:模型层(model)、控制层(presenter)、视图层(view)

1、创建User,添加@Entiy注解(实体类-表名)、@PrimaryKey注解(表示唯一主键)

import androidx.room.Entity;

import androidx.room.PrimaryKey;

@Entity

public class User {

@PrimaryKey

public long userId;

public String userName;

public String userAge;

public User(long userId, String userName, String userAge) {

this.userId = userId;

this.userName = userName;

this.userAge = userAge;

}

}

2、创建Dao,@Dao注解支持增删改查,@Query注解表示查询,@Insert注解表示插入,

onConflict = OnConflictStrategy.REPLACE 表示插入数据重复了直接修改保证数据的不重复。

import androidx.room.Dao;

import androidx.room.Insert;

import androidx.room.OnConflictStrategy;

import androidx.room.Query;

import com.example.model.bean.User;

import java.util.List;

import io.reactivex.Completable;

import io.reactivex.Flowable;

@Dao

public interface BookCaseDao {

@Query(“SELECT * FROM user”)

Flowable<List> getUser();

@Insert(onConflict = OnConflictStrategy.REPLACE)

Completable insert(User user);

}

3、创建RoomDatabase抽象类,供数据的操作使用。根据官网提示:获取数据库操作对象采用单例,节省内存开销。

@database注解表示RoomDatabase数据库对象,entities属性表示一张或多张表,version是版本号,

exprotSchema=false 不导出数据库到本地文件。

import android.content.Context;

import androidx.room.Database;

import androidx.room.Room;

import androidx.room.RoomDatabase;

import com.example.model.bean.User;

@Database(entities = {User.class},

version = 1,

exportSchema = false)

public abstract class AppDatabase extends RoomDatabase {

private static volatile AppDatabase INSTANCE;

public abstract BookCaseDao bookCaseDao();

public static AppDatabase getInstance(Context context) {

if (INSTANCE == null) {

synchronized (AppDatabase.class) {

if (INSTANCE == null) {

INSTANCE = Room.databaseBuilder(context,

AppDatabase.class, “user.db”).build();

}

}

}

return INSTANCE;

}

}

4、创建module:

import com.example.model.bean.User;

import java.util.List;

public interface UserIntFac {

void users(List users);

void addUserSuccess();

}

4、创建控制层presenter,将module作为控制层数据的回调:

import android.content.Context;

import com.example.model.bean.User;

import com.example.model.db.AppDatabase;

import com.example.userxroomhandledata.module.UserIntFac;

import java.util.List;

import io.reactivex.Completable;

import io.reactivex.Flowable;

import io.reactivex.android.schedulers.AndroidSchedulers;

import io.reactivex.disposables.CompositeDisposable;

import io.reactivex.functions.Action;

import io.reactivex.functions.Consumer;

import io.reactivex.schedulers.Schedulers;

public class UserPresenter {

public void addUser(User user) {

Completable insert = AppDatabase.getInstance(context).bookCaseDao().insert(user);

addDisposable(insert, new Action() {

@Override

public void run() throws Exception {

if (userIntFac != null) {

userIntFac.addUserSuccess();

}

}

});

}

public void getUsers() {

Flowable<List> users = AppDatabase.getInstance(context).bookCaseDao().getUser();

addDisposable(users, new Consumer<List>() {

@Override

public void accept(List users) throws Exception {

if (userIntFac != null) {

userIntFac.users(users);

}

}

});

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是关于Android Room数据库的简单介绍和使用方法: Android Room是一种SQLite数据库的对象映射库,它提供了一种简单的方法来访问SQLite数据库,而无需编写复杂的SQL查询。它是Google推出的一种Jetpack组件,旨在帮助Android开发者更加简便地使用SQLite数据库。 下面是使用Android Room数据库的基本步骤: 1. 添加依赖项:在app/build.gradle文件中添加以下依赖项: ``` dependencies { def room_version = "2.3.0" // Room components implementation "androidx.room:room-runtime:$room_version" annotationProcessor "androidx.room:room-compiler:$room_version" // optional - Kotlin Extensions and Coroutines support for Room implementation "androidx.room:room-ktx:$room_version" // optional - RxJava support for Room implementation "androidx.room:room-rxjava2:$room_version" // optional - Guava support for Room, including Optional and ListenableFuture implementation "androidx.room:room-guava:$room_version" // Test helpers testImplementation "androidx.room:room-testing:$room_version" } ``` 2. 创建实体:创建一个Java类或Kotlin数据类,用于表示数据库表中的一行数据。示例代码: ``` @Entity(tableName = "users") data class User( @PrimaryKey val id: Int, @ColumnInfo(name = "user_name") val userName: String, @ColumnInfo(name = "user_age") val userAge: Int ) ``` 3. 创建DAO:创建一个接口,其中包含用于访问数据库的方法。示例代码: ``` @Dao interface UserDao { @Query("SELECT * FROM users") fun getAllUsers(): List<User> @Insert(onConflict = OnConflictStrategy.REPLACE) fun insertUser(user: User) @Delete fun deleteUser(user: User) } ``` 4. 创建数据库:创建一个继承自RoomDatabase的抽象类,并在其中声明用于访问DAO的抽象方法。示例代码: ``` @Database(entities = [User::class], version = 1) abstract class AppDatabase : RoomDatabase() { abstract fun userDao(): UserDao } ``` 5. 初始化数据库:在应用程序的入口点处初始化数据库,并使用它来获取DAO实例。示例代码: ``` val db = Room.databaseBuilder( applicationContext, AppDatabase::class.java, "database-name" ).build() val userDao = db.userDao() ``` 6. 使用DAO:使用DAO中定义的方法来访问数据库。示例代码: ``` val allUsers = userDao.getAllUsers() userDao.insertUser(user) userDao.deleteUser(user) ``` 这些是使用Android Room数据库的基本步骤。当然,还有许多其他的高级用法和配置选项,可以根据具体需求进行学习和使用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值