harmony-utils之KvUtil,键值型数据库工具类

简介: harmony-utils之KvUtil是鸿蒙系统中用于操作键值型数据库的工具类,提供包括添加、获取、删除、批量操作及备份恢复等功能,简化数据存储与管理。

harmony-utils之KvUtil,键值型数据库工具类

harmony-utils 简介与说明


harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
picker_utils 是harmony-utils拆分出来的一个子库,包含PickerUtil、PhotoHelper、ScanUtil。

下载安装
ohpm i @pura/harmony-utils
ohpm i @pura/picker_utils

  //全局初始化方法,在UIAbility的onCreate方法中初始化 AppUtil.init()
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    AppUtil.init(this.context);
  }

API方法与使用


put 添加指定类型的键值对到数据库
KvUtil.put("name", "张三叁");
KvUtil.put("id", 10018);
KvUtil.put("sex", RandomUtil.getRandomBoolean());
KvUtil.put("info", RandomUtil.getRandomUint8Array(8));
get 获取指定键的值
 let kv1 = await KvUtil.get("name");
getString 获取指定键的值,string类型
 let kv2 = await KvUtil.getString('name');
getNumber 获取指定键的值,number类型
 let kv3 = await KvUtil.getNumber("id");
getBoolean 获取指定键的值,boolean类型
 let kv4 = await KvUtil.getBoolean('sex');
getUint8Array 获取指定键的值,uint8Array类型
 let kv5 = await KvUtil.getUint8Array('info');
delete 从数据库中删除指定键值的数据
KvUtil.delete("name");
ToastUtil.showToast('删除缓存成功');
putBatch 批量插入键值对到SingleKVStore数据库中
let entries: distributedKVStore.Entry[] = [];
for (let i = 0; i < 10; i++) {
  let key = 'batch_test_string_key';
  let entry: distributedKVStore.Entry = {
    key: key + i,
    value: {
      type: distributedKVStore.ValueType.STRING,
      value: 'batch_test_string_value'
    }
  }
  entries.push(entry);
}
KvUtil.putBatch(entries).then(() => {
  ToastUtil.showToast('批量插入成功');
}).catch((err: BusinessError) => {
  ToastUtil.showToast('批量插入异常!');
});
deleteBatch 批量删除SingleKVStore数据库中的键值对
let keys = ["batch_test_string_key0","batch_test_string_key1","batch_test_string_key2","batch_test_string_key3"];
KvUtil.deleteBatch(keys).then(() => {
  ToastUtil.showToast('批量删除成功');
}).catch((err: BusinessError) => {
  ToastUtil.showToast('批量删除异常!');
});
getEntries 获取匹配指定键前缀的所有键值对
let keyPrefix = "batch_test_string_key";
KvUtil.getEntries(keyPrefix).then((entries: distributedKVStore.Entry[]) => {
  Utils.showSheetText(JSON.stringify(entries, null, 2))
}).catch((err: BusinessError) => {
  ToastUtil.showToast(`异常信息:${err.message}`);
});
backup 以指定名称备份数据库
let backupFile = "BK001";
KvUtil.backup(backupFile, (err: BusinessError) => {
  if (err) {
    console.error(`Failed to backup.code is ${err.code},message is ${err.message} `);
  } else {
    console.info(`Succeeded in backupping data`);
  }
});
deleteBackup 根据指定名称删除备份文件
let files = ["BK001", "BK002"];
KvUtil.deleteBackup(files, (err: BusinessError, data: [string, number][]) => {
  if (err) {
    console.error(`Failed to delete Backup.code is ${err.code},message is ${err.message}`);
  } else {
    console.info(`Succeed in deleting Backup.data=${data}`);
  }
});
restore 从指定的数据库文件恢复数据库
let backupFile = "BK001";
KvUtil.restore(backupFile, (err: BusinessError) => {
  if (err) {
    console.error(`Failed to backup.code is ${err.code},message is ${err.message} `);
  } else {
    console.info(`Succeeded in backupping data`);
  }
});
onDataChange 订阅指定类型的数据变更通知
  private callBack: Callback<distributedKVStore.ChangeNotification> = (change) => {
    let pStr = JSON.stringify(change, null, 2);
    LogUtil.info(pStr);
  }

  KvUtil.onDataChange(distributedKVStore.SubscribeType.SUBSCRIBE_TYPE_ALL, callBack);
offDataChange 取消订阅数据变更通知
KvUtil.offDataChange(callBack);
ToastUtil.showToast('取消订阅数据变更通知');

创作不易,请给童长老点赞👍


https://github.com/787107497/harmony-utils
https://gitee.com/tongyuyan/harmony-utils
OpenHarmony三方库

目录
相关文章
|
8月前
|
JSON 缓存 生物认证
harmony-utils之FileUtil,文件相关工具类
FileUtil是HarmonyOS工具库harmony-utils中的文件操作工具类,提供丰富的文件管理功能,包括路径处理、文件读写、目录操作、文件属性获取等。它简化了HarmonyOS应用开发中的文件操作流程,提升开发效率。
269 0
|
8月前
|
JSON 生物认证 API
harmony-utils之EmitterUtil,Emitter工具类
harmony-utils之EmitterUtil是一款HarmonyOS应用开发中的事件通信工具类,支持事件的发送、订阅、单次订阅、取消订阅及订阅数查询等操作。它基于高效的事件驱动机制,简化了模块间的通信流程,提升开发效率,适用于复杂场景下的事件管理。
189 0
|
8月前
|
JSON 生物认证 API
harmony-utils之PermissionUtil,授权相关工具类
harmony-utils之PermissionUtil是HarmonyOS授权工具类,提供申请、校验及二次授权等方法,支持单个或多个权限操作,简化鸿蒙应用权限管理流程。
229 0
|
8月前
|
JSON 生物认证 API
harmony-utils之NotificationUtil,通知工具类
harmony-utils 是一款功能丰富的 HarmonyOS 工具库,提供通知、设备、文件等常用工具类。NotificationUtil 作为其子模块,专注于通知管理,支持普通、多行、长文本、图片及模板通知的发布与管理,简化鸿蒙应用开发流程。
193 0
|
8月前
|
JSON 5G 生物认证
harmony-utils之NetworkUtil,网络相关工具类
`harmony-utils` 是一款专为 HarmonyOS 开发的高效工具库,提供包括网络、设备、权限、文件等常用功能的封装。其中 `NetworkUtil` 工具类涵盖网络状态检测、类型判断、IP 获取、SIM 卡信息查询等功能,帮助开发者快速实现网络相关操作,提升开发效率。
221 0
|
8月前
|
JSON 生物认证 API
harmony-utils之PreviewUtil,文件预览工具类
PreviewUtil 是 harmony-utils 工具库中的文件预览工具类,提供生成预览信息、打开/关闭预览窗口、加载预览数据、判断预览支持等功能,助力鸿蒙应用快速实现文件预览操作。
276 0
|
8月前
|
JSON 生物认证 API
harmony-utils之PasteboardUtil,剪贴板工具类
harmony-utils 是一款功能丰富且易用的 HarmonyOS 工具库,提供剪贴板、设备、屏幕、授权等常用工具类,助力开发者高效构建鸿蒙应用。
177 0
|
8月前
|
JSON 生物认证 API
harmony-utils之LogUtil,日志工具类
harmony-utils 是一款功能强大的 HarmonyOS 工具库,涵盖日志、设备、通知、文件等常用开发模块。其中 LogUtil 提供丰富的日志操作方法,支持 DEBUG、INFO、WARN、ERROR、FATAL 等级别日志打印,便于开发者调试与维护应用,助力高效开发。
193 0
|
8月前
|
JSON 生物认证 API
harmony-utils之LocationUtil,定位相关工具类
harmony-utils 是一款专为 HarmonyOS 开发的高效工具库,包含丰富的实用类与功能模块。其中 LocationUtil 提供了定位服务判断、权限申请、位置获取、地理编码、坐标转换等功能,帮助开发者快速实现定位相关操作,提升开发效率。
203 0
|
8月前
|
JSON 生物认证 API
harmony-utils之ObjectUtil,对象工具类
`harmony-utils` 是一款专为 HarmonyOS 开发的功能强大且易于使用的工具库,涵盖对象操作、设备信息、文件处理、数据加密等常用开发功能,帮助开发者快速构建高效稳定的鸿蒙应用。
178 0