当前位置: 首页 > news >正文

HarmonyOS学习(十二)——数据管理(一)分布式数据

文章目录

        • 1、分布式数据服务概述
        • 2、KV数据模型(键值对数据库)
        • 3、分布式数据服务的约束和限制
        • 4、接口说明
        • 5、分布式数据服务开发步骤
          • 5.1、导入模块
          • 5.2、构造分布式数据库管理类实例
          • 5.3、获取、创建分布式数据库
          • 5.4、订阅分布式数据库的数据变化
          • 5.5、插入数据到分布式数据库
          • 5.6、查询分布式数据库数据
          • 5.7、删除分布式数据库数据

1、分布式数据服务概述

分布式数据服务(Distributed Data Service ,DDS)为应用程序提供不同设备间数据库的分布式协同能力。

通过调用分布式数据接口,应用程序将数据保存到分布式数据库中。通过结合账号,用用和数据库三元组,分布式数据服务对属于不同应用的数据进行隔离,以保证不同应用之间数据不能通过分布式数据服务互相访问。在通过可信认证的设备间,分布式数据服务支持应用数据相互同步,为用户提供在多种终端设备上最终一致的数据访问体验。

2、KV数据模型(键值对数据库)

KV数据模型是key-value数据模型的简称,其数据以键值对的形式进行组织、索引和存储。

3、分布式数据服务的约束和限制
  1. 分布式数据服务的数据模型仅支持KV模型,不支持外键,触发器等关系数据库中的功能。
  2. 设备协同数据库,针对每条记录,Key的长度≤896 Byte,Value的长度<4 MB。
  3. 单版本数据库,针对每条记录,Key的长度≤1 KB,Value的长度<4 MB。
  4. 每个应用程序最多支持同时打开16个键值型分布式数据库。
  5. 分布式数据库与本地数据库的使用场景不同,因此开发者应识别需要在设备间进行同步的数据,并将这些数据保存到分布式数据库中。
  6. 分布式数据服务针对每个应用当前的流控制机制:kvStore的接口一秒最多访问1000次,一分钟最多访问10000次;kvManager的接口一秒最多访问50次,一分钟最多访问500次。
  7. 分布式数据库事件回调方法中不允许进行阻塞操作,例如修改UI操作。
4、接口说明

以下是键值型数据库持久化功能的相关接口,大部分为异步接口。异步接口均有callback和Promise两种返回形式,下表均以callback形式为例。

接口名称描述
createKVManager(config: KVManagerConfig): KVManager创建一个KVManager对象实例,用于管理数据库对象。
getKVStore(storeId: string, options: Options, callback: AsyncCallback): void指定options和storeId,创建并得到指定类型的KVStore数据库。
put(key: string, value: Uint8Arraystring
get(key: string, callback: AsyncCallback<booleanstring
delete(key: string, callback: AsyncCallback): void从数据库中删除指定键值的数据。

5、分布式数据服务开发步骤
5.1、导入模块
import distributedKVStore from '@ohos.data.distributedKVStore';
5.2、构造分布式数据库管理类实例
let kvManager: distributedKVStore.KVManager | undefined = undefined;
export default class KvStoreDemoAbility extends UIAbility {onCreate(want, launchParam) {let context = this.context;const kvManagerConfig: distributedKVStore.KVManagerConfig = {context: context,bundleName: 'com.example.datamanagertest'}try {//创建KvManager实例kvManager = distributedKVStore.createKVManager(kvManagerConfig)hilog.info(0x0000, 'testTag', "Success in create kvmanager");} catch (e) {let error = e as BusinessError;console.error(`Failed to create KVManager. Code:${error.code},message:${error.message}`);}if (kvManager !== undefined) {kvManager = kvManager as distributedKVStore.KVManager;//进行后续操作//...}}
}
5.3、获取、创建分布式数据库
let kvStore: distributedKVStore.SingleKVStore | undefined = undefined;
try {const options: distributedKVStore.Options = {createIfMissing: true,encrypt: false,backup: false,autoSync: false,// kvStoreType不填时,默认创建多设备协同数据库kvStoreType: distributedKVStore.KVStoreType.SINGLE_VERSION,// 多设备协同数据库:kvStoreType: distributedKVStore.KVStoreType.DEVICE_COLLABORATION,securityLevel: distributedKVStore.SecurityLevel.S1};kvManager.getKVStore<distributedKVStore.SingleKVStore>('storeId', options, (err, store: distributedKVStore.SingleKVStore) => {if (err) {console.error(`Failed to get KVStore: Code:${err.code},message:${err.message}`);return;}console.info('Succeeded in getting KVStore.');kvStore = store;// 请确保获取到键值数据库实例后,再进行相关数据操作});
} catch (e) {let error = e as BusinessError;console.error(`An unexpected error occurred. Code:${error.code},message:${error.message}`);
}
if (kvStore !== undefined) {kvStore = kvStore as distributedKVStore.SingleKVStore;//进行后续操作//...
}
5.4、订阅分布式数据库的数据变化
try {kvStore.on('dataChange', distributedKVStore.SubscribeType.SUBSCRIBE_TYPE_LOCAL, function (data) {console.info('datachange callback data:' + JSON.stringify(data))});
} catch (e) {console.info('An unexpected error occured .Erroe:${e}')
}
5.5、插入数据到分布式数据库

调用put()方法向键值对数据库插入数据,当key值存在时,put()方法会修改其值,否则会新增一条数据。

const KEY_TEST_STRING_ELEMENT = 'key_test_string';
const VALUE_TEST_STRING_ELEMENT = 'value_test_string';
try {kvStore.put(KEY_TEST_STRING_ELEMENT, VALUE_TEST_STRING_ELEMENT, (err) => {if (err !== undefined) {console.error(`Failed to put data. Code:${err.code},message:${err.message}`);return;}console.info('Succeeded in putting data.');});
} catch (e) {let error = e as BusinessError;console.error(`An unexpected error occurred. Code:${error.code},message:${error.message}`);
}
5.6、查询分布式数据库数据

调用get()方法获取指定键的值

try {kvStore.put(KEY_TEST_STRING_ELEMENT, VALUE_TEST_STRING_ELEMENT, (err) => {if (err !== undefined) {console.error(`Failed to put data. Code:${err.code},message:${err.message}`);return;}console.info('Succeeded in putting data.');kvStore = kvStore as distributedKVStore.SingleKVStore;kvStore.get(KEY_TEST_STRING_ELEMENT, (err, data) => {if (err != undefined) {console.error(`Failed to get data. Code:${err.code},message:${err.message}`);return;}console.info(`Succeeded in getting data. Data:${data}`);});});
} catch (e) {let error = e as BusinessError;console.error(`Failed to get data. Code:${error.code},message:${error.message}`);
}
5.7、删除分布式数据库数据

调用delete()方法删除指定键值的数据

try {kvStore.put(KEY_TEST_STRING_ELEMENT, VALUE_TEST_STRING_ELEMENT, (err) => {if (err !== undefined) {console.error(`Failed to put data. Code:${err.code},message:${err.message}`);return;}console.info('Succeeded in putting data.');kvStore = kvStore as distributedKVStore.SingleKVStore;kvStore.delete(KEY_TEST_STRING_ELEMENT, (err) => {if (err !== undefined) {console.error(`Failed to delete data. Code:${err.code},message:${err.message}`);return;}console.info('Succeeded in deleting data.');});});
} catch (e) {let error = e as BusinessError;console.error(`An unexpected error occurred. Code:${error.code},message:${error.message}`);
}

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • C#实战|大乐透选号器[7]:设计类和对象的方法
  • 共享单车轨迹数据分析:以厦门市共享单车数据为例(四)
  • 【四】k8s部署 TDengine集群
  • Unity3D Android多渠道极速打包方案详解
  • 【机器学习】使用Numpy实现神经网络训练全流程
  • 【资料分析】平均倍数类
  • 【重学 MySQL】十八、逻辑运算符的使用
  • iOS 知识点记录
  • vm-tools的卸载重装,只能复制粘贴,无法拖拽文件!
  • 大数据新视界 --大数据大厂之Kafka消息队列实战:实现高吞吐量数据传输
  • 详解IOC、AOP及常见面试问题
  • SpringBoot 项目 Jar 包加密,防止反编译
  • ZBrush与Blender雕刻功能哪个更好些?
  • 价值、创新、社区与财富效应:Match项目的成功启示
  • Python+Pytest框架,“conftest.py文件编写如何获取token和获取日志“?
  • [rust! #004] [译] Rust 的内置 Traits, 使用场景, 方式, 和原因
  • 2019.2.20 c++ 知识梳理
  • Angular4 模板式表单用法以及验证
  • Bytom交易说明(账户管理模式)
  • co模块的前端实现
  • echarts花样作死的坑
  • Flex布局到底解决了什么问题
  • golang 发送GET和POST示例
  • JavaScript类型识别
  • jdbc就是这么简单
  • leetcode386. Lexicographical Numbers
  • Node项目之评分系统(二)- 数据库设计
  • Python学习之路13-记分
  • React as a UI Runtime(五、列表)
  • React Native移动开发实战-3-实现页面间的数据传递
  • Zepto.js源码学习之二
  • 案例分享〡三拾众筹持续交付开发流程支撑创新业务
  • 前端面试总结(at, md)
  • 如何设计一个比特币钱包服务
  • 通过几道题目学习二叉搜索树
  • 新书推荐|Windows黑客编程技术详解
  • elasticsearch-head插件安装
  • MPAndroidChart 教程:Y轴 YAxis
  • Nginx惊现漏洞 百万网站面临“拖库”风险
  • ​补​充​经​纬​恒​润​一​面​
  • #{}和${}的区别是什么 -- java面试
  • #ifdef 的技巧用法
  • (C语言)输入自定义个数的整数,打印出最大值和最小值
  • (非本人原创)我们工作到底是为了什么?​——HP大中华区总裁孙振耀退休感言(r4笔记第60天)...
  • (附源码)spring boot基于Java的电影院售票与管理系统毕业设计 011449
  • (附源码)springboot教学评价 毕业设计 641310
  • (附源码)springboot优课在线教学系统 毕业设计 081251
  • (亲测成功)在centos7.5上安装kvm,通过VNC远程连接并创建多台ubuntu虚拟机(ubuntu server版本)...
  • (亲测有效)推荐2024最新的免费漫画软件app,无广告,聚合全网资源!
  • (三)模仿学习-Action数据的模仿
  • (五)Python 垃圾回收机制
  • (一)Dubbo快速入门、介绍、使用
  • (转)PlayerPrefs在Windows下存到哪里去了?
  • .babyk勒索病毒解析:恶意更新如何威胁您的数据安全
  • .chm格式文件如何阅读