HarmonyOS笔记4:从云数据库获取数据
移动应用获取数据的方式主要有:
1.从网络中获取数据接口API。
2.从华为云数据库获取云数据库的资源。
3.从移动终端直接获取本地的数据
在HarmonyOS笔记3中已经完成了方式一从网络中获取数据接口API的方式。在本篇笔记中,将讨论从云数据库中获取数据。
因为采用SDK API12中模拟器测试一直不能成功,从技术论坛某篇求助帖看到,需要真机才能成功。因此,在这篇笔记中将采SDK API9的版本,开发工具是DevEco Studio 3.1.0版本。特此说明。
开发基于云数据库的移动应用需要按照下图的步骤进行:
一、注册华为开发者账号
访问网站“https://developer.huawei.com/consumer/cn/”,需要提供个人信息进行注册,并开通“实名认证”,具体操作略。
二、进入AGC控制台
登录华为开发者账号后,访问网站“https://developer.huawei.com/consumer/cn/service/josp/agc/index.html#/”进入"AppGallery Connect"控制台,如图1所示:
图1 AGC控制台
1.创建新的项目
在图1所示的页面中,点击“我的项目”。
图2 “我的项目“
在”我的项目"界面中,点击"添加项目”,进入项目编辑界面,配置项目信息。
图3 创建项目
设置项目的名称,并点击“创建并继续”,在后续的操作中,因为仅仅是一个测试应用,因此将默认的“为此项目启动分析服务”关闭,点击“完成”
图4 开通分析服务
如果希望开通,也可以直接启动分析服务。在此不再赘述。
2.创建新的应用
返回"AGC 控制台",选择"证书、APP ID和Profile"项目,如下图所示:
图5 AGC控制台
在AGC页面中,选择“证书、APP ID和Profile”,进入页面“证书、APP ID和Profile”,然后点击“新建”,如图5所示:
图5 选择 “APP ID”
在后续的APP ID页面中配置“设置应用开发基础信息”。
图6 编辑移动应用基础信息
注意,包名与后续开发的移动应用的包名一致。点击“下一步”,为新建的应用配置所属的项目,如下图所示。
图7 配置应用所属的项目
在点击“确认”后,开通“认证服务”。
图8 检索认证服务,并开通认证服务
图9 创建新应用成功
3.开通并配置云数据库
返回AGC 控制台,如图10所示,选择"云数据库":
图10 AGC 控制台
在AGC 控制台中,选择“云数据库”,进入图11所示的云数据库页面:
图11 云数据库
在云数据库页面中,选择“立即开通”。为指定的应用设置数据处理的位置。
图12 配置数据处理位置
配置云数据库所在的地理位置,此处配置为“中国”,设为默认位置,点击“确定”,进入“云数据库 for Object"。
图13 云数据库 for Object
点击”新建“,新建数据对象类型,如图14所示。
图14 配置数据对象类型名
然后分别依次配置数据对象类型的“字段”,“索引”和“数据权限”。
图15配置数据对象字段
图16配置索引
图17 配置数据权限
为了后续的操作方便,此处将所有的权限进行勾选。配置数据对象完毕后,继续执行导出数据类型对象的操作,如图18所示:
图18 数据类型对象
分别导出json格式文件和js格式文件。
图19 导出json格式文件
图20 导出js格式文件
导出的文件是一个压缩包,压缩包内包含一个js文件。将压缩包解压后的js文件(此处是MedalInfo.js)暂时保存起来,以备后续使用。此处导出的json文件和js文件均可以为后续的开发提供支持。
然后,设置数据对象类型(相当于数据表)的存储区。点击“新增”
图21 进入存储区
图22 配置存储区
图23 进入存储的数据
点击“新增”,进入数据的配置界面,如图24所示。
图24 新增数据
这种一个一个数据输入的方式非常繁琐,也可以直接批量导入数据。
图25 选择要导入文件操作
图26 选择要导入的文件
导入的文件格式是JSON形式,类似如下所示:
{"cloudDBZoneName": "MedalZone","objectTypeName": "MedalInfo","objects": [{"areaId": "CHN","areaName": "中国","goldMedal": 40,"silverMedal": 27,"bronzeMedal": 24,"areaIcon": "https://gstatic.olympics.com/s1/t_original/static/noc/oly/3x2/180x120/CHN.png"},{"areaId": "USA","areaName": "美国","goldMedal": 40,"silverMedal": 44,"bronzeMedal": 42,"areaIcon": "https://gstatic.olympics.com/s1/t_original/static/noc/oly/3x2/180x120/USA.png"},//...更多的记录略
}
此处:
“cloudDBZoneName”: “MedalZone”:表示存储区,与设置的数据类型的存储区名一致。
“objectTypeName”: “MedalInfo”:表示数据类型名称,与定义的数据类型名一致。
"objects"表示的是存储的数据,采用json数组的形式。
可以点击“查询”,可以检索的所有的数据,如图27所示。
图27 检索所有的数据
返回AGC 控制的常规页面,如图28所示:
图28 常规页面
在该页面中下载下载最新的配置文件“agconnect-service.json”,为后续的移动开发提供支持。
三、开发移动应用
启动DevEco Studio 3.1.0版本,新建项目如下所示:
图28 创建项目
其中,包名必须与AGC 控制台创建应用的包名一致。
1.配置相关的文件
将下载的配置文件"agconnect-services.json"文件复制到resources/rawfile目录中,如图29所示:
图29 复制agconnect-services.json文件到rawfile目录
配置当前模块的module.json5文件,增加互联网访问权限的内容,代码片段如下所示:
图30 module.json5增加互联网访问权限
"requestPermissions": [{"name": "ohos.permission.INTERNET"}]
打开DevEco Studio 3.1.0 应用级oh-package.json5文件,在oh-package.json5文件里面添加SDK依赖,添加SDK依赖完成后,点击右上方“Sync Now”同步。
{"name": "entry","version": "1.0.0","description": "Please describe the basic information.","main": "","author": "","license": "","dependencies": {"@hw-agconnect/database-ohos":"^1.1.2","@hw-agconnect/core-ohos": "^1.1.2"}
}
2.定义数据类型
在ets目录下创建一个model目录,将下载的数据类型的js文件,复制到model目录。另外,在model目录中新建一个app-schema.json文件,将上述导出的数据类型的json文件,复制粘贴到app-schema.json文件中。
图31 定义数据类型
3. 定义访问云数据库的服务
创建service目录,在该目录下定义一个typescript文件CloudDBService.ts文件,定义执行对云数据库操作的各种业务处理,具体代码如下:
import { AGConnectCloudDB, CloudDBZoneConfig, CloudDBZone, CloudDBZoneQuery } from '@hw-agconnect/database-ohos';
// @ts-ignore
import schema from '../model/app-schema.json';
import { AGCRoutePolicy } from "@hw-agconnect/core-ohos";
import { MedalInfo } from '../model/MedalInfo';export class CloudDBService {//必须与AGC控制台指定云数据库的存储区名一致private static readonly ZONE_NAME = 'MedalZone';private static cloudDB: AGConnectCloudDB;private static cloudDBZone: CloudDBZone;private static isInit: boolean;/*** 初始化** @param context context* @returns 是否初始化成功*/public static async init(context: any): Promise<boolean> {if (this.isInit) {return;}try {// 初始化并获取AGConnectCloudDBthis.cloudDB = await AGConnectCloudDB.getInstance({context: context, // 在eTS页面中通过全局方法getContext(this)获取当前页面关联的ContextagcRoutePolicy: AGCRoutePolicy.CHINA, // 数据处理位置,CHINA-中国区,GERMANY-德国,RUSSIA-俄罗斯,SINGAPORE-新加坡objectTypeInfo: schema});// 打开存储区await this.openZone(this.ZONE_NAME);this.isInit = true;} catch (err) {console.error(`初始化失败,因为:${JSON.stringify(err)}`)}return Promise.resolve(this.isInit);}/*** 打开存储区** @param zoneName 存储区名称* @returns*/private static async openZone(zoneName: string): Promise<void> {if (this.cloudDBZone) {console.log('zone has been closed.')return;}try {const cloudDBZoneConfig = new CloudDBZoneConfig(zoneName);this.cloudDBZone = await this.cloudDB.openCloudDBZone(cloudDBZoneConfig);console.log('[openZone] open zone success.')} catch (e) {console.error('[openZone] open zone failed. e:' + e);console.error(JSON.stringify(e));}}/*** 查询并排序数据* * @param queryStr 查询条件,可为空* @returns 查询数据结果数组*/public static async queryRecord(queryStr?: string): Promise<Array<MedalInfo>> {try {//按照金牌的个数进行排序const query = CloudDBZoneQuery.where(MedalInfo).orderByDesc("goldMedal");if (queryStr) {query.contains('areaName', queryStr);}const result = await this.cloudDBZone.executeQuery(query);return result.getSnapshotObjects();} catch (e) {console.error('[queryRecord] queryRecord failed. e:' + JSON.stringify(e));return [];}}
}
4. 定义Index.ets的UI页面
import { MedalInfo } from '../model/MedalInfo'
import { CloudDBService } from '../service/CloudDBService'@Entry
@Component
struct Index {@State medalLst:Array<MedalInfo> = []onPageShow(){this.queryAll()}build() {Column(){Row({space:10}){Text("").width(60).height(20)Text("国家/地区").width(60).height(20)Text("金牌").width(60).height(20)Text("银牌").width(60).height(20)Text("铜牌").width(60).height(20)}List(){ForEach(this.medalLst,(item:MedalInfo)=>{ListItem(){Row({space:10}){Image(`${item.areaIcon}`).width(60).height(40)Text(`${item.areaName}`).width(60).height(40)Text(`${item.goldMedal}枚`).width(60).height(40)Text(`${item.silverMedal}枚`).width(60).height(40)Text(`${item.bronzeMedal}枚`).width(60).height(40)}}.width("100%").margin(10)})}}.width("100%").height("100%")}async queryAll(){try{// 初始化await CloudDBService.init(getContext(this));// 查询数据并展示this.medalLst = await CloudDBService.queryRecord();}catch(err){console.error(`出现错误:${JSON.stringify(err)}`)}}
}
5.运行结果
图32 最后的运行结果
后记
这篇笔记是比较艰难的一篇。一方面是在云数据库的配置,整个详细过程需要截取大量的图片;另外一方面,就是测试了若干版本的DevEco Studio,以及SDK API 12的版本测试云数据库,一直不能在模拟机中测试通过。直到看到这一帖子,让我不再纠结。因此,退而求其次,采用SDK API 9的版本。希望,过段时间,再出一篇SDK API 12版本云数据库处理的笔记。
参考文献
1.AppGallery Connect帮助中心 https://developer.huawei.com/consumer/cn/doc/app/agc-help-getstarted-0000001100316670
2.使用云数据库组件 https://developer.huawei.com/consumer/cn/doc/AppGallery-connect-Guides/agc-clouddb-component-harmonyosts-0000001623209420
相关文章:

HarmonyOS笔记4:从云数据库获取数据
移动应用获取数据的方式主要有: 1.从网络中获取数据接口API。 2.从华为云数据库获取云数据库的资源。 3.从移动终端直接获取本地的数据 在HarmonyOS笔记3中已经完成了方式一从网络中获取数据接口API的方式。在本篇笔记中,将讨论从云数据库中获取数据。 因…...

QT5生成独立运行的exe文件
目录 1 生成独立运行的exe文件1.1 设置工程Release版本可执行文件存储路径1.2 将工程编译成Release版本 2 使用QT5自带的windeployqt拷贝软件运行依赖项3 将程序打包成一个独立的可执行软件exe4 解决QT5 This application failed to start because no Qt platform plugin could…...

LabVIEW光纤水听器闭环系统
开发了一种利用LabVIEW软件开发的干涉型光纤水听器闭环工作点控制系统。该系统通过调节光源频率和非平衡干涉仪的光程差,实现了工作点的精确控制,从而提高系统的稳定性和检测精度,避免了使用压电陶瓷,使操作更加简便。 项目背景 …...

Shell——流程控制语句(if、case、for、while等)
在 Shell 编程中,流程控制语句用于控制脚本的执行顺序和逻辑。这些语句包括 if、case、for、while 等,它们的使用可以使脚本实现更复杂的逻辑。以下是它们的详细说明和语法结构: 1. if 语句 if 语句用于条件判断,执行符合条件的…...

【redis的大key问题】
在使用 Redis 的过程中,如果未能及时发现并处理 Big keys(下文称为“大Key”),可能会导致服务性能下降、用户体验变差,甚至引发大面积故障。 本文将介绍大Key产生的原因、其可能引发的问题及如何快速找出大Key并将其优…...

HighPoint SSD7749M2:128TB NVMe 存储卡实现28 GB/s高速传输
HighPoint Technologies推出了一款全新的SSD7749M2 RAID卡,能够在标准的桌面工作站中安装多达16个M.2 SSD,实现高达128TB的闪存存储。该卡通过PCIe Gen4 x16接口提供高达28 GB/s的顺序读写性能。这些令人瞩目的性能规格伴随着高昂的价格标签。 #### 技术…...

ARM 裸机与 Linux 驱动对比及 Linux 内核入门
目录 ARM裸机代码和驱动的区别 Linux系统组成 内核五大功能 设备驱动分类 内核类型 驱动模块 驱动模块示例 Makefile配置 命令 编码辅助工具 内核中的打印函数 printk 函数 修改打印级别 编辑 打印级别含义 驱动多文件编译 示例 模块传递参数 命令行传递参数…...

0101DNS TCP fallback on UDP query timeout disabled-redission-中间件
文章目录 1.问题描述2.临时解决方案 结语 1.问题描述 Springcloud 项目,微服务模块使用redission,启动报错 DNS TCP fallback on UDP query timeout disabled. Upgrade Netty to 4.1.105 or higher.相关软件版本如下 软件版本描述springboot2.7.18spr…...

位运算
x1010 原码:000...1010 (一共32位) 反码:111...0101 (~x) 补码:111...0110 (反码1)(-x) 1、n 的二进制表示中第 k 位是几 #include<iost…...

MemFire Cloud是否真的可以取代后端
近年来,随着前端技术的迅速发展,前端工程师们越来越多地开始思考一个问题:“我还能不能不依赖后端?” 这种想法并非空穴来风,尤其是随着像MemFire Cloud这样的工具出现,它不仅能让开发者在没有后端的情况下…...

数据结构(邓俊辉)学习笔记】优先级队列 06——完全二叉堆:批量建堆
文章目录 1. 自上而下的上滤:算法2. 自上而下的上滤:效率3. 自下而上的下滤:算法4. 自下而上的下滤:实例5. 自下而上的下滤:效率 1. 自上而下的上滤:算法 在介绍过完全二叉堆标准的静态和动态操作接口之后…...

Java | Leetcode Java题解之第344题反转字符串
题目: 题解: class Solution {public void reverseString(char[] s) {int n s.length;for (int left 0, right n - 1; left < right; left, --right) {char tmp s[left];s[left] s[right];s[right] tmp;}} }...

定制开发AI智能名片O2O商城小程序:基于限量策略与个性化追求的营销创新
摘要:随着科技的飞速发展和消费者需求的日益多元化,传统商业模式正经历着前所未有的变革。在数字化转型的大潮中,定制开发AI智能名片O2O商城小程序作为一种新兴的商业模式,凭借其独特的个性化定制能力、高效的线上线下融合(O2O&am…...

Spring MVC Controller返回json日期格式配置失效的解决办法
如题,Spring MVC 4.3.0版本,配置jackson读写json。Controller层方法返回值对象包含java.util.Date类型的属性,并且在applicationContext.xml中配置了jackson的日期格式: <mvc:annotation-driven><mvc:message-converters…...

3.Default Constructor的构造操作
目录 1. 问题引入 2. 4种implicitly声明的default constructor 1. 问题引入 “default constructors......在需要的时候被编译产生出来”。关键词是“在需要的时候”,被谁需要,做什么事情?看看下面的代码,然后梳理下思路。 cl…...

CSS的:current伪类:精准定位当前活动元素
CSS(层叠样式表)是控制网页样式的核心语言。随着CSS4的提出,一系列新的选择器被引入,其中:current伪类便是这些新特性之一。:current伪类允许开发者选择当前处于活动状态的元素,这在创建动态和交互性网页时非常有用。本…...

搭建个人网站
一 个人搭建网站需要进行的操作 详细步骤: 1 网站目标:搭建在线查看法拍房拍卖价格的预测模型,输出预测结果 2 实际功能:在线爬取 阿里法拍网站的信息 3 根据实时模型建模预测法拍价格和成交概率 要搭建一个能够在线查看法拍房拍卖…...

机器学习课程学习周报八
机器学习课程学习周报八 文章目录 机器学习课程学习周报八摘要Abstract一、机器学习部分1.1 self-attention的计算量1.2 人类理解代替自注意力计算1.2.1 Local Attention/Truncated Attention1.2.2 Stride Attention1.2.3 Global Attention1.2.4 聚类Query和Key 1.3 自动选择自…...

福泰轴承股份有限公司进销存系统pf
TOC springboot413福泰轴承股份有限公司进销存系统pf 绪论 1.1 研究背景 现在大家正处于互联网加的时代,这个时代它就是一个信息内容无比丰富,信息处理与管理变得越加高效的网络化的时代,这个时代让大家的生活不仅变得更加地便利化&#…...

【k8s从节点报错】error: You must be logged in to the server (Unauthorized)
k8s主节点可以获取nodes节点信息,但是从节点无法获取,且报错“error: You must be logged in to the server (Unauthorized)” 排查思路: 当时证书过期了,只处理的主节点的证书过期,没有处理从节点的 kubeadm alpha …...

风清扬/基于Java语言的光伏监控系统+光伏发电预测+光伏项目+光伏运维+光伏储能项目
基于Java语言的光伏监控系统光伏发电预测光伏项目光伏运维光伏储能项目 介绍 基于Java语言的光伏监控系统光伏发电系统光伏软件系统光伏监控系统源码光伏发电系统源码 基于Java语言的光伏监控系统光伏发电预测光伏项目光伏运维光伏储能项目 安装教程 参与贡献 Fork 本仓库新…...

Datawhale X 魔搭 AI夏令营第四期 魔搭-AIGC方向全过程笔记
task1: 传送门 task2: 传送门 task3: 传送门 目录 Task1 赛题内容 可图Kolors-LoRA风格故事挑战赛 baseline要点讲解(请配合Datawhale速通教程食用) Step1 设置算例及比赛账号的报名和授权 Step2 进行赛事报名并创建PAI实例 Step3 执行baseline Step4…...

数组---怎么样定义和引用数组
一怎么定义数组 例 int a[10]; //定义了一个一维数组,数组名为a,此数组包含10个整型元素 所以我们了解到数组的基本定义为 类型符 数组名 [常量表达式] 定义数组可以包括常量和符号常量如 int [ 35 ];但是不能利用变量定义如 int n; …...

Nginx—Rewrite
目录 一、Nginx—Rewrite概述 1、常用的Nginx正则表达式 2、Rewrite功能 3、Rewrite跳转实现 4、Rewrite执行顺序和语法格式 二、location概述 1、location分类 2、location 常用的匹配规则 3、location 优先级 案例一: 案例二: 案例三&…...

《深入浅出WPF》读书笔记.5控件与布局(上)
《深入浅出WPF》读书笔记.5控件与布局(上) 背景 深入浅出WPF书籍学习笔记附代码。WPF中数据是核心是主动的,UI是数据的表达是被动的。 程序的本质是数据算法;控件的本质是数据行为; 5.控件与布局 一、6类控件派生关系 1.布局控件:可以容纳多个控件…...

二叉树的判断
二叉树的判断 判断一颗二叉树是不是搜索二叉树 (左边的比根小,右边的比根大) 中序遍历一下,如果是的话就一定是升序的 如何判断一颗二叉树是否是完全二叉树 1.遍历任意的节点时候,如果返回右孩子没有左孩子&#x…...

Hive3:常用的内置函数
1、查看函数列表 -- 查看所有可用函数 show functions; -- 查看count函数使用方式 describe function extended count;2、数学函数 -- round 取整,设置小数精度 select round(3.1415926); -- 取整(四舍五入) select round(3.1415926, 4); -- 设置小数精度4位(四…...

设计模式---构建者模式(Builder Pattern)
构建者模式(Builder Pattern) 是一种创建型设计模式,旨在将复杂对象的构建过程与其表示分离。它允许使用相同的构建过程创建不同的表示。该模式通常用于构建复杂对象,这些对象由多个部分组成或具有多个可选属性。 构建者模式的核…...

Pytorch中transform的应用
在PyTorch中,transforms模块主要用于对图像进行预处理和数据增强,以便于训练深度学习模型。这些转换操作可以包括裁剪、缩放、旋转、翻转等,以及对图像进行标准化处理。下面将详细介绍一些常用的transforms操作及其应用。 1. 常用的transfor…...

okular阅读软件简介
okular阅读软件官网:https://okular.kde.org/zh-cn/ Okular 是一款由 KDE 开发的跨平台文档阅读器,以其功能丰富、轻巧快速而著称。它支持多种文件格式,包括 PDF、EPub、DjVu、MD 文档,以及 JPEG、PNG、GIF、Tiff 和 WebP 图像&a…...