KVStorage:小巧强大的轻量级Android-仿NoSQL
如何把用户信息存入Android SQLite数据库?
KVStorage.rxSave("user", new Gson.toJson(userInfo)).subscribe();
库连接:https://github.com/Reone/KVStorage
一、为什么要读这篇文章
- 你会看到用一行代码保存用户信息到Android数据库
- 你会看到如何抄袭ReactNative的Android数据库
- 你会看到Android轻量级数据库:RxDatabase
- 你会看到基于Android SQLite的NoSQL数据库实现
二、依赖KVStorage之前你可能会有的问题
1.Key-Value存取为什么不使用SharedPreference?
SharedPreference不适合大数据的存储,具体原因可以查找资料,不要滥用SharedPreference
这里简单的列几个比较严重的问题:
- 第一次从sp中获取值的时候,有可能阻塞主线程,使界面卡顿、掉帧。
- 解析sp的时候会产生大量的临时对象,导致频繁GC,引起界面卡顿。
- 被SharedPreferences加载进来的这些大对象,会永远存在于内存之中,不会被释放.
- SharedPreferences是线程不安全的。
2.什么叫NoSQL数据库?NoSQL数据库有什么优势?
NoSQL,泛指非关系型的数据库。KVStorage属于键值(Key-Value)存储数据库。注意KVStorage并不完全属于NoSQL,其底层由sqlite实现。
3.为什么用RxJava替换AsynTask?
除了RxJava人尽皆知的可读性好之外,还有便于生命周期管理等优势,更多优势可查阅用RxJava.Observable取代AsyncTask和AsyncTaskLoader-RxJava Android模版
4.KVStorage有多轻?
其实库中只有一个java文件,标准格式,代码不超过400行。
三、从抄袭ReactNative到KVStorage
1.定位目标
1.RN保存数据时使用setItem方法,可以定位到 AsyncStorage.js
setItem: function(
key: string,
value: string,
callback?: ?(error: ?Error) => void
): Promise {
return new Promise((resolve, reject) => {
RCTAsyncStorage.multiSet([[key,value]], function(errors) {
var errs = convertErrors(errors);
callback && callback(errs && errs[0]);
if (errs) {
reject(errs[0]);
} else {
resolve(null);
}
});
});
},
异步调用了RCTAsyncStorage.multiSet
2.找到项目中RN库中对应的文件 AsyncStorageModule.java
AsyncStorageModule.multiSet(final ReadableArray keyValueArray, final Callback callback)
3.根据关联找到RN源码库中关于RN storage的四个主要文件
- AsyncLocalStorageUtil.java
- AsyncStorageErrorUtil.java
- AsyncStorageModule.java
- ReactDatabaseSupplier.java
2.RN Storage主要文件功能介绍
-
AsyncLocalStorageUtil.java
提供了保存、合并保存与查找的同步实现,提供了SQL查询语句的构建工具。
-
AsyncStorageErrorUtil.java
当操作出现错误时,用以构建可供js使用的错误信息。
-
AsyncStorageModule.java
js代码映射的java文件,提供js使用的数据库操作方法。
-
ReactDatabaseSupplier.java
继承SQLiteOpenHelper,实现了数据库创建、更新、关闭、设置最大值的功能。提供SQLiteDatabase的获取方法。
-
ReadableArray.java
js数据与java数据的适配类型。可以使java接受js参数。
-
WritableMap.java
js数据与java数据的适配类型。可以使js接受java参数。
3.KVStorage的形成过程
- KVStorage是仅提供Android使用的库,所以关于类型转换的操作不需要。从文件的主要功能介绍来看,我仅保留ReactDatabaseSupplier和AsyncLocalStorageUtil即可,随将二者合并。
- 使用数组替换ReadableArray。
- 修改方法权限,将ReactDatabaseSupplier私有。
- 用support注解替换javax的注解,添加修改一些注解。
- 使用rxJava代替AsynTask实现异步操作。
四、KVStorage正式介绍
a simple easy NoSQL database
- 一个简单的容易使用的数据库
- 仅一个文件400行java代码
- 非关系型Key-value数据库
- 底层使用sqlite实现
1.使用环境
- java8
- rxJava
- rxAndroid
2.引用,添加依赖
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
dependencies {
implementation 'com.github.Reone:KVStorage:v1.0.1'
}
3.KVStorage依赖说明
dependencies {
implementation 'com.android.support:appcompat-v7:27.1.1'
implementation "io.reactivex.rxjava2:rxjava:2.1.5"
implementation "io.reactivex.rxjava2:rxandroid:2.0.1"
}
4.使用方式
详细的使用可以查看SimpleActivity
- 在Application中初始化
KVStorage.init(context);
- 保存
KVStorage.rxSave(demoKey, demoValue).subscribe();
- 查找
KVStorage.rxGet(demoKey)
.subscribe(new AsyncObserver<String>() {
@Override
public void onSuccess(String result) {
}
@Override
public void onError(Throwable e) {
}
});
- 删除/批量删除
KVStorage.rxRemove(demoKey).subscribe();
KVStorage.rxRemove(demoKey1,demoKey2).subscribe();
5.功能接口
- 异步保存
- 同步保存
- 异步获取
- 异步删除
- 获取所有key
- 清除所有key
- 合并保存json
- 待开发...