KVStorage:小巧强大的轻量级Android-仿NoSQL

2018-09-19  本文已影响0人  Reone_JS

如何把用户信息存入Android SQLite数据库?
KVStorage.rxSave("user", new Gson.toJson(userInfo)).subscribe();

库连接:https://github.com/Reone/KVStorage

一、为什么要读这篇文章

  1. 你会看到用一行代码保存用户信息到Android数据库
  2. 你会看到如何抄袭ReactNative的Android数据库
  3. 你会看到Android轻量级数据库:RxDatabase
  4. 你会看到基于Android SQLite的NoSQL数据库实现

二、依赖KVStorage之前你可能会有的问题

1.Key-Value存取为什么不使用SharedPreference?

SharedPreference不适合大数据的存储,具体原因可以查找资料,不要滥用SharedPreference
这里简单的列几个比较严重的问题:

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的四个主要文件

2.RN Storage主要文件功能介绍

提供了保存、合并保存与查找的同步实现,提供了SQL查询语句的构建工具。

3.KVStorage的形成过程

  1. KVStorage是仅提供Android使用的库,所以关于类型转换的操作不需要。从文件的主要功能介绍来看,我仅保留ReactDatabaseSupplier和AsyncLocalStorageUtil即可,随将二者合并。
  2. 使用数组替换ReadableArray。
  3. 修改方法权限,将ReactDatabaseSupplier私有。
  4. 用support注解替换javax的注解,添加修改一些注解。
  5. 使用rxJava代替AsynTask实现异步操作。

四、KVStorage正式介绍

a simple easy NoSQL database

1.使用环境

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

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.功能接口

上一篇下一篇

猜你喜欢

热点阅读