安卓数据库框架——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

相关文章

SpringBoot集成图片验证码框架easy-captcha的详细过程

《SpringBoot集成图片验证码框架easy-captcha的详细过程》本文介绍了如何将Easy-Captcha框架集成到SpringBoot项目中,实现图片验证码功能,Easy-Captcha是... 目录SpringBoot集成图片验证码框架easy-captcha一、引言二、依赖三、代码1. Ea

Gin框架中的GET和POST表单处理的实现

《Gin框架中的GET和POST表单处理的实现》Gin框架提供了简单而强大的机制来处理GET和POST表单提交的数据,通过c.Query、c.PostForm、c.Bind和c.Request.For... 目录一、GET表单处理二、POST表单处理1. 使用c.PostForm获取表单字段:2. 绑定到结

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

MySQL进阶之路索引失效的11种情况详析

《MySQL进阶之路索引失效的11种情况详析》:本文主要介绍MySQL查询优化中的11种常见情况,包括索引的使用和优化策略,通过这些策略,开发者可以显著提升查询性能,需要的朋友可以参考下... 目录前言图示1. 使用不等式操作符(!=, <, >)2. 使用 OR 连接多个条件3. 对索引字段进行计算操作4

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意