鸿蒙实现数据管理

目录:

    • 1、鸿蒙实现数据管理的三种方式
    • 2、用户首选项
    • 3、键值型数据管理
      • 3.1、获取KVManager实例,用于管理数据库对象
      • 3.2、创建并获取键值数据库
      • 3.3、调用put()方法向键值数据库中插入数据
      • 3.4、调用get()方法获取指定键的值
      • 3.5、调用delete()方法删除指定键值的数据
    • 4、关系型数据管理
      • 4.1、导入模块
      • 4.2、在abliity入口文件的生命周期函数onWindowStageCreat中添加初始化代码
      • 4.3、RdbUtils工具类
      • 4.4、创建数据库
      • 4.5、插入数据
      • 4.6、查询数据
      • 4.7、修改和删除数据
      • 4.8、删除数据库

1、鸿蒙实现数据管理的三种方式

  • 用户首选项
  • 键值型数据管理
  • 关系型数据管理

在这里插入图片描述

2、用户首选项

import dataPreferences from '@ohos.data.preferences';
import preferences from '@ohos.data.preferences';
import { Log } from './Log';
import { ValueType } from '@kit.ArkData';/*** 用户首选项工具类*/
export class PreferencesUtil {static mPreferences ?: dataPreferences.Preferences/*** 初始化* @param context*/static init(context: Context) {try {dataPreferences.getPreferences(context, 'Looper_Sp', (err, preferences) => {if (err) {Log.error(`Failed to get preferences. Code:${err.code},message:${err.message}`);return;}PreferencesUtil.mPreferences = preferencesLog.info('Succeeded in getting preferences.');// 进行相关数据操作})} catch (err) {Log.error(`Failed to get preferences. Code:${err.code},message:${err.message}`);}}/*** 写数据* @param isFlush 是否持久化*/static writeData(key: string, value: ValueType, isFlush: boolean): Promise<boolean> {return new Promise((resolve, reject) => {try {PreferencesUtil.mPreferences?.put(key, value, (err) => {if (err) {Log.error(`Failed to put data. Code:${err.code}, message:${err.message}`);reject(false);return;}Log.info('Succeeded in putting data.');if (isFlush) {PreferencesUtil.flushData()}resolve(true);})} catch (err) {Log.error(`Failed to check the key 'startup'. Code:${err.code}, message:${err.message}`);reject(false);}});}/*** 读取数据*/static readData<D>(key: string): Promise<D> {return new Promise((resolve, reject) => {if (PreferencesUtil.mPreferences == null) {reject(new Error("mPreferences is null"));} else {PreferencesUtil.mPreferences.get(key, "", (err, value) => {if (err) {reject(err);return;}resolve(value as D);})}});}/*** 删除数据* @param isFlush 是否持久化*/static delData(key: string, isFlush: boolean): Promise<string> {return new Promise((resolve, reject) => {if (PreferencesUtil.mPreferences == null) {reject(new Error("mPreferences is null"));} else {PreferencesUtil.mPreferences.delete(key, (err, value) => {if (err) {reject(err);return;}if (isFlush) {PreferencesUtil.flushData()}resolve("删除成功");})}});}/*** 删除整个库* @param isFlush 是否持久化*/static delDB(context: Context, storeName: string): Promise<string> {return new Promise((resolve, reject) => {dataPreferences.deletePreferences(context, storeName, (err, value) => {if (err) {reject(err);return;}resolve("删除成功");})});}/*** 持久化*/static flushData() {if (PreferencesUtil.mPreferences != null) {try {PreferencesUtil.mPreferences.flush((err) => {if (err) {Log.error(`Failed to flush. Code:${err.code}, message:${err.message}`);return;}Log.info('Succeeded in flushing.');})} catch (err) {Log.error(`Failed to flush. Code:${err.code}, message:${err.message}`);}}}
}let preferencesUtil = new PreferencesUtil()export default preferencesUtil as PreferencesUtil
//下面首选项的方法可以在这里面执行,页面栈创建时就初始化用户首选项,就可以直接在代码中使用了
onWindowStageCreate(ability, windowStage) {
PreferencesUtil.init(this.context)
console.info(TAG, “onWindowStageCreate ability:+ JSON.stringify(ability));
console.info(TAG, “onWindowStageCreate windowStage:+ JSON.stringify(windowStage));
}
//sp储存初始化
PreferencesUtil.init(this.context)
//写入信息
PreferencesUtil.writeData("zzz", "bbb", true)
//读取信息
PreferencesUtil.readData<string>("zzz").then(res => {Log.info("读取数据:" + res)})

3、键值型数据管理

3.1、获取KVManager实例,用于管理数据库对象

// 导入模块
import { distributedKVStore } from '@kit.ArkData';// Stage模型
import { window } from '@kit.ArkUI';
import { UIAbility } from '@kit.AbilityKit';
import { BusinessError } from '@kit.BasicServicesKit';let kvManager: distributedKVStore.KVManager | undefined = undefined;export default class EntryAbility extends UIAbility {onCreate() {let context = this.context;const kvManagerConfig: distributedKVStore.KVManagerConfig = {context: context,bundleName: 'com.example.datamanagertest'};try {// 创建KVManager实例kvManager = distributedKVStore.createKVManager(kvManagerConfig);console.info('Succeeded in creating 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;//进行后续操作//...
}

3.2、创建并获取键值数据库

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;//进行后续操作//...
}

3.3、调用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}`);
}

说明:

当Key值存在时,put()方法会修改其值,否则新增一条数据。

3.4、调用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}`);
}

3.5、调用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}`);
}

4、关系型数据管理

4.1、导入模块

import relationalStore from '@ohos.data.relationalStore'; // 导入模块 

4.2、在abliity入口文件的生命周期函数onWindowStageCreat中添加初始化代码

const STORE_CONFIG = {name: 'RdbTest.db', // 数据库文件名securityLevel: relationalStore.SecurityLevel.S1 // 数据库安全级别};relationalStore.getRdbStore(this.context, STORE_CONFIG, (err, store) => {if (err) {console.error(`Failed to get RdbStore. Code:${err.code}, message:${err.message}`);return;}console.info(`Succeeded in getting RdbStore.`);//保存store, 方便后面我们对数据库的操作RdbUtils.setStore(store)});

4.3、RdbUtils工具类

import relationalStore from '@ohos.data.relationalStore';
export default class RdbUtils {private static rdbStore: relationalStore.RdbStore;static setStore(store: relationalStore.RdbStore) {RdbUtils.rdbStore = store;}static getStore(): relationalStore.RdbStore {return RdbUtils.rdbStore;}
}

4.4、创建数据库

import relationalStore from '@ohos.data.relationalStore';
export default class RdbUtils {...static executeSql(sql: string): Promise<void> {return RdbUtils.getStore().executeSql(sql);}...
}

示例:

import RdbUtils from '../common/rdbUtils/RdbUtils';
@Entry
@Component
struct Index {build() {Row() {Column() {Button('创建数据库表').onClick(() => {const SQL_CREATE_TABLE = 'CREATE TABLE IF NOT EXISTS EMPLOYEE (ID INTEGER PRIMARY KEY AUTOINCREMENT, NAME TEXT NOT NULL, AGE INTEGER, SALARY REAL, CODES BLOB)'; // 建表Sql语句RdbUtils.executeSql(SQL_CREATE_TABLE).then(() =>{openDialog('successfully created table')}).catch((err) => {openDialog(err);})})}.width('100%')}.height('100%')}
}function openDialog(text: string) {AlertDialog.show({title: 'title',message: text,autoCancel: true,alignment: DialogAlignment.Bottom,offset: { dx: 0, dy: -20 },})
}

4.5、插入数据

import relationalStore from '@ohos.data.relationalStore';
export default class RdbUtils {...static insert(tableName: string, data: any): Promise<number> {return RdbUtils.getStore().insert(tableName, data);}...
}

示例:

import RdbUtils from '../common/rdbUtils/RdbUtils';
@Entry
@Component
struct Index {build() {Row() {Column() {...Button('插入数据').onClick(() => {const valueBucket = {'NAME': 'Lisa','AGE': 18,'SALARY': 100.5,'CODES': new Uint8Array([1, 2, 3, 4, 5])};RdbUtils.insert('EMPLOYEE', valueBucket).then((updateNumber) => {openDialog('已插入数据:' + updateNumber)}).catch((error) => {openDialog('error: ' + error)})})...}.width('100%')}.height('100%')}
}
...

4.6、查询数据

static queryAll(): Promise<Array<Employee>> {let predicates = new relationalStore.RdbPredicates('EMPLOYEE');return new Promise<Array<Employee>>((resolve, reject) => {RdbUtils.getStore().query(predicates).then((result) => {let employees = new Array<Employee>();while (result.goToNextRow()) {let employee = new Employee(result.getLong(0),result.getString(1),result.getLong(2),result.getDouble(3),result.getBlob(4));employees.push(employee);}resolve(employees);}).catch((error) => {reject(error)})})}

该方法将通过RdbUtils.getStore().query(predicates)获取的结果集封装到Employee类中,然后通过Promise进行返回。

实体类Employee:

export default class Employee {id: number; // 员工IDname: string; // 姓名age: number | null; // 年龄,允许为nullsalary: number | null; // 工资,允许为nullcodes: Uint8Array | null; // 二进制数据,用于存储 BLOB 类型,允许为nullconstructor(id: number, name: string, age: number | null, salary: number | null, codes: Uint8Array | null) {this.id = id;this.name = name;this.age = age;this.salary = salary;this.codes = codes;}
}

示例:

import RdbUtils from '../common/rdbUtils/RdbUtils';
@Entry
@Component
struct Index {build() {Row() {Column() {...Button('查询数据').onClick(() => {RdbUtils.queryAll().then((employees: Array<Employee>) => {openDialog('employees: ' + JSON.stringify(employees))}).catch((error) => {openDialog('error' + error.toString())})})...}.width('100%')}.height('100%')}
}
...

4.7、修改和删除数据

在工具包中添加:

...static deleteById(id: number) {let predicates = new relationalStore.RdbPredicates('EMPLOYEE');predicates.equalTo('ID', id)return RdbUtils.getStore().delete(predicates);}static updateById(id: number, data: any) {let predicates = new relationalStore.RdbPredicates('EMPLOYEE');predicates.equalTo('ID', id)return RdbUtils.getStore().update(data, predicates);}
...
      	Button('修改数据').onClick(() => {const valueBucket = {'NAME': 'Rose','AGE': 999,'SALARY': 100.5,'CODES': new Uint8Array([1, 2, 3, 4, 5])};RdbUtils.updateById(1, valueBucket).then((updateNumber) => {openDialog('已更新数据:' + updateNumber.toString())}).catch((err) => {openDialog(err)})})Button('删除数据').onClick(() => {RdbUtils.deleteById(1).then((updateNumber) => {openDialog('已删除数据:' + updateNumber.toString())}).catch((err) => {openDialog(err)})})

4.8、删除数据库

export default class EntryAbility extends UIAbility {...onDestroy() {hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onDestroy');relationalStore.deleteRdbStore(this.context, 'RdbTest.db', (err) => {if (err) {console.error(`Failed to delete RdbStore. Code:${err.code}, message:${err.message}`);return;}console.info('Succeeded in deleting RdbStore.');});}....
}

这里我在EntryAbility中的onDestroy生命周期函数中调用了删除数据库的操作,这意味着当我们的Ability被销毁的时候,自动将数据库删除。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/488426.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JAVA面试汇总(三)集合(一)

JAVA多线程七篇终于写完了&#xff0c;今天开始了新的JAVA面试汇总&#xff0c;集合部分&#xff0c;这部分其实比多线程有意思多了&#xff0c;这个计划最多五篇&#xff0c;也许不到五篇&#xff0c;这是第一篇&#xff0c;开卷。 1.Collection和Collections 的区别&#xff…

使用 ASP.NET Core HttpLoggingMiddleware 记录 http 请求/响应

我们发布了一个应用程序&#xff0c;该应用程序运行在一个相当隐蔽的 WAF 后面。他们向我们保证&#xff0c;他们的产品不会以任何方式干扰我们的应用程序。这是错误的。他们删除了我们几乎所有的“自定义”标头。为了“证明”这一点&#xff0c;我构建了一个中间件&#xff0c…

qt 封装 调用 dll

这个目录下 &#xff0c;第一个收藏的这个 &#xff0c;可以用&#xff0c; 但是有几个地方要注意 第一.需要将dll的头文件添加到qt的文件夹里面 第二&#xff0c;需要在pro文件里面添加动态库路径 第三&#xff0c;如果调用dll失败&#xff0c;那么大概需要将dll文件放在e…

基于自注意力网络的SASRec

运用了自注意力网络&#xff08;self-attention network&#xff0c;SAN&#xff09;的序列推荐算法&#xff08;SASRec&#xff09;能以并行化的方式捕捉同一序列上不同时间步间的转移关系&#xff0c;最后通过加权求和的方式得出每个时间步的序列特征。 算法原理&#xff1a;…

从一个Bug谈前端响应拦截器的应用

一、问题场景 今天在开发商品管理系统时&#xff0c;遇到了一个有趣的问题&#xff1a;当添加重复的商品编号时&#xff0c;页面同时弹出了两条 "商品编号已存在" 错误提示&#xff1a; 这个问题暴露了前端错误处理机制的混乱&#xff0c;让我们从这个问题出发&…

【机器学习chp9】集成学习

一、集成学习的概念 1. 什么是集成学习 定义&#xff1a;集成学习是一种通过组合多个模型&#xff08;称为基学习器&#xff09;来提升整体系统性能的方法。优点&#xff1a; 单个模型性能可能已经优化到极限&#xff0c;难以进一步提高&#xff0c;集成学习通过少量额外工作…

复合机器人整体解决方案

复合机器人是一种集成移动机器人和协作机器人两项功能为一身的新型机器人&#xff0c;更符合人们想象中“脑、眼、手、脚”融合的机器人终极形态。复合机器人的整体解决方案通常涉及多个方面&#xff0c;包括机器人本体、控制系统、感知系统、执行系统以及周边配套设备等。以下…

SpringBoot【十】mybatis之xml映射文件>、<=等特殊符号写法!

一、前言&#x1f525; 环境说明&#xff1a;Windows10 Idea2021.3.2 Jdk1.8 SpringBoot 2.3.1.RELEASE 在利用mybatis进行开发的时候&#xff0c;编写sql时可能少不了>、<等比较符号&#xff0c;但是在mapper映射文件中直接使用是不行的&#xff0c;会报错&#xff0…

Elasticsearch:使用阿里 infererence API 及 semantic text 进行向量搜索

在之前的文章 “Elasticsearch 开放推理 API 新增阿里云 AI 搜索支持”&#xff0c;它详细描述了如何使用 Elastic inference API 来针对阿里的密集向量模型&#xff0c;稀疏向量模型&#xff0c; 重新排名及 completion 进行展示。在那篇文章里&#xff0c;它使用了很多的英文…

windows下Qt5自动编译配置QtMqtt环境(11)

文章目录 [toc]1、概述2、准备1.1 下载源码1.2 配置环境1.3 解释原理 3、编译4、验证5、参考6、视频 更多精彩内容&#x1f449;内容导航 &#x1f448;&#x1f449;Qt网络编程 &#x1f448; 1、概述 Qt默认是不包含mqtt库的&#xff0c;如果需要使用到mqtt库就只能自己编译配…

关于OpenAI Sora上线!AI视频生成的新纪元

OpenAI Sora的上线无疑是人工智能领域的一个重要进展&#xff0c;它标志着AI技术在视频生成和编辑方面迈出了一大步。 引言 在人工智能的快速发展中&#xff0c;OpenAI的最新力作——Sora&#xff0c;标志着AI视频生成技术的一个新纪元。Sora的上线不仅是技术上的一次飞跃&am…

K8S对接ceph的RBD块存储

1 PG数量限制问题 1.1 原因分析 1.还是老样子&#xff0c;先创建存储池&#xff0c;在初始化为rbd。 [rootceph141~]# ceph osd pool create wenzhiyong-k8s 128 128 Error ERANGE: pg_num 128 size 3 for this pool would result in 295 cumulative PGs per OSD (2067 tot…

Windows11安装Isaac Lab

1.1 下载文件 将 Isaac Lab 仓库克隆到您的工作空间&#xff1a; git clone https://github.com/isaac-sim/IsaacLab.git 1.2 创建Isaac Sim符号链接 F:cd IsaacLab 官方文档里路径/有问题&#xff0c;改成\&#xff09;&#xff1a; # 打开IsaacLab目录cd IsaacLab# 使用…

NES游戏机项目制作笔记(未完成)

24年12月1日晚记——在网上找项目学习的时候发现一个有意思的项目&#xff0c;准备靠这个应用一些STM32的高级功能。值得提醒的是——目的在于学习不可贪杯&#xff0c;注意效率 01 根据项目需求分析 为确保充分考虑每一个细节&#xff0c;并且让自己高效的完成项目制作&#…

ElasticSearch - 理解doc Values与Inverted Index倒排索引

文章目录 概述倒排索引&#xff1a;从图书馆的索引卡片谈起倒排索引的工作原理 docValues&#xff1a;从数据库的列式存储说起docValues的工作原理 docValues与倒排索引的对比两者的联系&#xff1a;组合使用&#xff0c;优化搜索与分析 小结 概述 在使用 Elasticsearch 进行大…

前端H5移动端基础框架模板 :Vue3 + Vite5 + Pinia + Vant4 + Sass + 附源码

技术栈选用 Vue3 Vite5 Pinia Vant4 Sass 源码地址&#xff1a; git clone https://gitee.com/gaiya001/h5-APP.git1. 1.vite.config.js文件配置 ** import { defineConfig } from vite // 导入 Vite 的配置函数 import vue from vitejs/plugin-vue // 导入 Vue 插件 i…

游戏引擎学习第36天

仓库 :https://gitee.com/mrxiao_com/2d_game 回顾之前的内容 在这个程序中&#xff0c;目标是通过手动编写代码来从头开始制作一个完整的游戏。整个过程不使用任何库或现成的游戏引擎&#xff0c;这样做的目的是为了能够全面了解游戏执行的每一个细节。开发过程中&#xff0…

C++小碗菜之五:GDB调试工具

“程序员不是编写代码的人&#xff0c;而是调试错误的人。” – 约翰本尼斯&#xff08;John Bennet&#xff09; 目录 前言 在虚拟机中安装 GDB GDB调试的实战演练 创建示例代码 例子&#xff1a; 使用 GDB 调试 编译代码 启动 GDB 设置断点 运行程序 打印变量值 …

【软件测试面试题】测试理论/基础面试(持续更新)

Hi&#xff0c;大家好。最近很多朋友都在说今年的互联网行情不好&#xff0c;面试很难&#xff0c;不知道怎么复习&#xff0c;我最近总结了一份在软件测试面试中比较常见的测试理论/基础面试面试题合集&#xff0c;希望对大家有帮助。建议点赞收藏再阅读&#xff0c;防止丢失&…

(css)element中el-select下拉框整体样式修改

(css)element中el-select下拉框整体样式修改 重点代码&#xff08;颜色可行修改&#xff09; // 修改input默认值颜色 兼容其它主流浏览器 /deep/ input::-webkit-input-placeholder {color: rgba(255, 255, 255, 0.50); } /deep/ input::-moz-input-placeholder {color: rgba…