Android使用Room操作数据库流程详解

 更新时间:2022年11月17日 09:59:52   作者:Flynn_MIMD  
谷歌推荐使用Room操作数据库,Room在 SQLite 上提供了一个抽象层,在充分利用 SQLite强大功能的同时,能够流畅地访问数据库

Room的三个主要组件:

  • 数据库类,用于保存数据库并作为应用持久性数据底层连接的主要访问点。
  • 数据实体,@Entity,表示数据库中的表。
  • 数据访问对象 (DAO),@Dao,提供查询、更新、插入和删除数据的方法。

build.gradle添加

dependencies {
    def room_version = "2.4.3"

    implementation "android.arch.persistence.room:runtime:$room_version"
    annotationProcessor "android.arch.persistence.room:compiler:$room_version" 

    implementation "android.arch.persistence.room:rxjava2:$room_version"

    testImplementation "android.arch.persistence.room:testing:$room_version"
}

1. 创建实体类User

@Entity(tableName = "users")
public class User {
    @PrimaryKey
    public int uid;
    @ColumnInfo(name = "first_name")
    public String firstName;
    @ColumnInfo(name = "last_name")
    public String lastName;
}

@Entity实体类,users表的名称,不加默认user

@ColumnInfo列名

@PrimaryKey主键

2. 创建DAO

@Dao
public interface UserDao {
    @Query("SELECT * FROM user")
    List<User> getAll();
    @Query("SELECT * FROM user WHERE uid IN (:userIds)")
    List<User> loadAllByIds(int[] userIds);
    @Query("SELECT * FROM user WHERE first_name LIKE :first AND " +
            "last_name LIKE :last LIMIT 1")
    User findByName(String first, String last);
    @Insert(onConflict = OnConflictStrategy.REPLACE)
    void insertAll(User... users);
    @Delete
    void delete(User user);
}

增,删,改:将实例与表的主键进行匹配

查询结果将自动映射到对应类型的字段,若未映射将报警告

3. 数据库

抽象类AppDatabase 定义数据库配置,并作为应用对持久性数据的主要访问点,扩展了RommDataBase

@Database(entities = {User.class}, version = 1, exportSchema = false)
public abstract class AppDataBase extends RoomDatabase {
    public abstract UserDao userDao();
}

4. 使用

AppDataBase db = Room.databaseBuilder(getApplicationContext(),
                        AppDataBase.class, "database-name").build();
                for (int i = 0; i < 10; i++) {
                    User user = new User();
                    user.uid = i;
                    user.firstName = "Shell" + i;
                    user.lastName = "Hub" + i;
                    db.userDao().insertAll( user);
                    List<User> userList = db.userDao().getAll();
                    for(User user1 : userList) {
                        Log.d("mip",""+user1.firstName);
                    }
                }

为了节约获取数据库的时间和资源,采取单例模式

简单实现:

public class Utils {
    private static AppDataBase db = null;
    private static Context context = null;
    public static AppDataBase getDb(){
        if( db == null) {
            db = Room.databaseBuilder(context,
                    AppDataBase.class, "database-name").build();
        }
        return db;
    }
    public static void setContext(Context context){
        Utils.context = context;
    }
}

调用

public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Utils.setContext(getApplicationContext());
        new Thread(new Runnable() {
            @Override
            public void run() {
                AppDataBase db = Utils.getDb();
                for (int i = 0; i < 10; i++) {
                    User user = new User();
                    user.uid = i;
                    user.firstName = "Shell" + i;
                    user.lastName = "Hub" + i;
                    db.userDao().insertAll( user);
                    List<User> userList = db.userDao().getAll();
                    for(User user1 : userList) {
                        Log.d("mip",""+user1.firstName);
                    }
                }
            }
        }).start();
    }
}

路过的大佬们有更好的单例实现请告诉我一下,

到此这篇关于Android使用Room操作数据库流程详解的文章就介绍到这了,更多相关Android Room内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Android  setButtonDrawable()的兼容问题解决办法

    Android setButtonDrawable()的兼容问题解决办法

    这篇文章主要介绍了Android setButtonDrawable()的兼容问题解决办法的相关资料,需要的朋友可以参考下
    2017-03-03
  • Android中AsyncTask异步任务使用详细实例(一)

    Android中AsyncTask异步任务使用详细实例(一)

    AsyncTask是Android提供的轻量级的异步类,可以直接继承AsyncTask,在类中实现异步操作,并提供接口反馈当前异步执行的程度(可以通过接口实现UI进度更新),最后反馈执行的结果给UI主线程,通过本文给大家介绍Android中AsyncTask异步任务使用详细实例(一),需要的朋友参考下
    2016-02-02
  • Android智能指针轻量级Light Pointer初识

    Android智能指针轻量级Light Pointer初识

    这篇文章主要为大家介绍了Android智能指针轻量级Light Pointer初识详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Android开发基础使用ProgressBar加载进度条示例

    Android开发基础使用ProgressBar加载进度条示例

    这篇文章主要介绍了安卓开发基础使用ProgressBar加载进度条示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • 详解Android 8.0以上系统应用如何保活

    详解Android 8.0以上系统应用如何保活

    这篇文章主要介绍了详解Android 8.0以上系统应用如何保活,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • 详解Android消息机制完整的执行流程

    详解Android消息机制完整的执行流程

    经过前面几篇文章的铺垫,介绍了Hanlder、Message等类相关使用,分析了其与Looper、MessageQueue的部分源码,本篇文章主要是集中梳理Android整个消息机制执行的完整流程,需要的可以参考一下
    2022-10-10
  • Android实现简单的加载进度条

    Android实现简单的加载进度条

    这篇文章主要为大家详细介绍了Android实现简单的加载进度条,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05
  • Android编程实现文字倒影效果的方法

    Android编程实现文字倒影效果的方法

    这篇文章主要介绍了Android编程实现文字倒影效果的方法,涉及Android布局与图形绘制相关操作技巧,需要的朋友可以参考下
    2017-03-03
  • SDL2和OpenGL使用踩坑笔记经验分享

    SDL2和OpenGL使用踩坑笔记经验分享

    今天小编就为大家分享一篇关于SDL2和OpenGL使用踩坑笔记经验分享,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • Android开发实现图片切换APP

    Android开发实现图片切换APP

    这篇文章主要介绍了Android开发实现图片切换APP,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-12-12

最新评论