安卓数据库框架——Realm进阶学习

2024-06-09 16:32

本文主要是介绍安卓数据库框架——Realm进阶学习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


安卓数据库框架——Realm进阶学习

参考:

https://realm.io/cn/docs/java/latest/#realms

http://ngudream.com/2016/08/13/realm-builder/

 

Real的配置

基础配置

一般我们不配置migration和modules。

存储

Realm一般是建立一个数据库,如果仅仅希望存到内存,也是可以用的:


在realm完全关闭的时候会被释放。

Realm线程及监听

Realm可以实现不同线程中读取和写入 Realm 对象,即线程安全。同时,在Realm中的数据改变时,可以进行监听:

Realm监听:

在 Realm 数据改变的时候会被触发。


集合监听:       

当集合中的某对象的属性改变时被触发,当然这个属性的改变需能保证该元素仍然满足查询条件从而使其仍然存在于集合当中。



对象监听:

为某个 Realm 对象注册监听器以获得针对对象属性修改的细粒度通知:

 

Json转换

可以直接将json对象转换成Realm对象并存储:


databaseHelper的封装:


public class GoodsDBHelper {
   
private static volatile GoodsDBHelper mInstance;
    private final
RealmConfiguration mDefaultConfig;
    private
ArrayList<RealmConfiguration> mConfigsList = new ArrayList<>();
    private
GoodsDBHelper(){
       
super();
        
mDefaultConfig = new RealmConfiguration.Builder()
                .
name("PDA_Goods.realm") //文件名
               
.schemaVersion(0) //版本号
               
.build();
   
}

   
public static GoodsDBHelper getInstance(){
       
if(mInstance == null){
           
synchronized (GoodsDBHelper.class){
               
if(mInstance == null){
                   
mInstance = new GoodsDBHelper();
               
}
            }
        }
       
return mInstance;
   
}

   
private Realm createRealm() {
       
return createRealmByConfig(mDefaultConfig);
   
}

   
private Realm createRealmByConfig(RealmConfiguration config){
       
mConfigsList.add(config);
        return
Realm.getInstance(config);
   
}

   
/**
     *
添加物资基本信息
     * @param
info
    
*/
   
public void insertGoodsInfo(GoodsInfo info){
       
Realm realm = createRealm();
       
realm.beginTransaction();
       
realm.copyToRealmOrUpdate(info);
       
realm.commitTransaction();
       
realm.close();
   
}

   
/**
     *
查询指定物资
     * @param
goodsID
     
* @return
    
*/
   
@Nullable
   
public GoodsInfo queryGoodsInfo(String goodsID){
       
Realm realm = createRealm();
       
GoodsInfo info = realm.where(GoodsInfo.class).equalTo("userId", goodsID).findFirst();
       
GoodsInfo result = null;
        if
(info != null) {
           
result = realm.copyFromRealm(info);
       
}
       
realm.close();
        return
result;
   
}

   
/**
     *
查询全部用户
     * @return
    
*/
   
public List<GoodsInfo> queryGoodsInfos(){
       
Realm realm = createRealm();
       
RealmResults<GoodsInfo> realmResults = realm.where(GoodsInfo.class).findAll();
       
List<GoodsInfo> arrayList = realm.copyFromRealm(realmResults);
       
realm.close();
        return
arrayList;
   
}

   
/**
     *
删除指定用户
     * @param
userId
    
*/
   
public void deleteGoodsInfo(String userId){
       
Realm realm = createRealm();
       
GoodsInfo info = realm.where(GoodsInfo.class).equalTo("userId", userId).findFirst();
        if
(info != null) {
           
realm.beginTransaction();
           
info.deleteFromRealm();
           
realm.commitTransaction();
       
}
       
realm.close();
   
}

   
/**
     *
删除全部用户信息
     */
   
public void deleteAllGoodsInfo(){
       
Realm realm = createRealm();
       
realm.beginTransaction();
       
realm.delete(GoodsInfo.class);
       
realm.commitTransaction();
       
realm.close();
   
}

}

 

 

 

这篇关于安卓数据库框架——Realm进阶学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1045707

相关文章

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Win11安装PostgreSQL数据库的两种方式详细步骤

《Win11安装PostgreSQL数据库的两种方式详细步骤》PostgreSQL是备受业界青睐的关系型数据库,尤其是在地理空间和移动领域,:本文主要介绍Win11安装PostgreSQL数据库的... 目录一、exe文件安装 (推荐)下载安装包1. 选择操作系统2. 跳转到EDB(PostgreSQL 的

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应