成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

DevEco Studio端云協同開發之云數據庫體驗

開發 前端
本節將結合端云協同開發,將啟動頁需要的參數保存到云數據庫中,實現根據特定節氣顯示不同的啟動頁背景圖。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

在??自定義HamronyOS啟動頁組件??一文中封裝了啟動頁組件,本節將結合端云協同開發,將啟動頁需要的參數保存到云數據庫中,實現根據特定節氣顯示不同的啟動頁背景圖。

一、環境

二、云數據庫

云數據庫(Cloud DB)是Serverless服務提供的能力之一,是AppGallery Connect平臺解決方案的一部分,是端云協同的數據庫產品,支持數據在端云、多端之間無縫同步,并為應用提供離線支持,以幫助開發者快速構建端云、多端協同應用,開發者可以聚集于應用本身業務,極大提升開發者開發效率,更多請至??華為App Gallery Connect云數據庫??了解。

三、端云協同開發云數據庫

DevEco Studio 3.1 Beta1提供了端云協同開發,可以通過云側CloudProgram項目創建云數據庫對象類型、存儲區、配置權限,端側引入相關的云數據庫文件即可進行云數據庫數據操作,應用開發流程如下圖所示:

DevEco Studio端云協同開發之云數據庫體驗-開源基礎軟件社區

1、云側CloudProgram工程云數據庫配置

(1)創建對象類型

云數據庫采用存儲區、對象類型和對象三級結構基于對象模型的數據庫。對象類型是用于定義存儲對象的集合,不同對象類型對應的不同數據結構。

在云側CloudProgram工程clouddb目錄下clouddb目錄右鍵??New > Cloud DB Object Type??創建對象類型,輸入對象類型名稱,DevEco Studio會自動創建初始對象類型JSON文件。

在對象類型JSON文件中,可以配置字段、索引以及角色于權限,表3-1為數據類型JSON文件屬性簡單介紹。

表3-1 數據類型JSON文件屬性(更多描述參見官方文檔)

參數

說明

fields

數據表字段集,配置屬性參見表3-2

indexes

數據表索引,配置屬性參見表3-3

permissions

操作數據表角色及對應權限,配置屬性參見表3-4

objectTypeName

數據表名稱

DevEco Studio端云協同開發之云數據庫體驗-開源基礎軟件社區

表3-2 數據表字段(更多描述參見官方文檔)

參數

說明

fieldName

字段名稱

fieldType

字段數據類型

當前支持:String, Boolean, Byte, Shor, Integer, Long, Float, Double, ByteArray, Text, Date, IntAutoIncrement, LongAutoIncrement

belongPrimaryKey

字段是否為主鍵

notNull

字段值是否為空

isNeedEncrypt

字段是否需要加密

"fields": [
{
"belongPrimaryKey": true,
"fieldName": "id",
"fieldType": "Integer",
"isNeedEncrypt": false,
"notNull": true
},
{
"belongPrimaryKey": false,
"fieldName": "timer",
"fieldType": "Integer",
"isNeedEncrypt": false,
"notNull": false
},
{
"belongPrimaryKey": false,
"fieldName": "isLogo",
"fieldType": "Boolean",
"isNeedEncrypt": false,
"notNull": false
},
{
"belongPrimaryKey": false,
"fieldName": "backgroundImg",
"fieldType": "String",
"isNeedEncrypt": false,
"notNull": false
},
{
"belongPrimaryKey": false,
"fieldName": "companyName",
"fieldType": "String",
"isNeedEncrypt": false,
"notNull": false
},
{
"belongPrimaryKey": false,
"fieldName": "mFontColor",
"fieldType": "String",
"isNeedEncrypt": false,
"notNull": false
},
{
"belongPrimaryKey": false,
"fieldName": "status",
"fieldType": "Integer",
"isNeedEncrypt": false,
"notNull": false
},
{
"belongPrimaryKey": false,
"fieldName": "createUser",
"fieldType": "Integer",
"isNeedEncrypt": false,
"notNull": false
},
{
"belongPrimaryKey": false,
"fieldName": "createTime",
"fieldType": "Date",
"isNeedEncrypt": false,
"notNull": false
}
],

表3-3 數據表索引(更多描述參見官方文檔)。

參數

說明

indexName

索引名稱

indexList

索引包含的字段

"indexes": [
{
"indexName": "IDX_202302221057",
"indexList": [
{
"fieldName": "id",
"sortType": "DESC"
}
]
}
],

表3-4 操作數據表角色及權限(更多描述參見官方文檔)。

參數

說明

World

所有用戶,默認最多僅可擁有Read權限

Authenticated

AppGallery Connect登錄的認證用戶

Creator

數據創建用戶

Administrator

應用開發者

"permissions": [
{
"rights": [
"Read"
],
"role": "World"
},
{
"rights": [
"Read",
"Upsert"
],
"role": "Authenticated"
},
{
"rights": [
"Read",
"Upsert",
"Delete"
],
"role": "Creator"
},
{
"rights": [
"Read",
"Upsert",
"Delete"
],
"role": "Administrator"
}
]

(2)創建數據條目

創建完對象類型,可以通過為對象類型添加數據條目,來預置數據庫內容,支持手動創建和自動生成數據條目JSON文件。

  • 手動創建數據條目文件:在clouddb目錄下dataentry目錄右鍵New > Cloud DB Data Entry創建數據條目JSON文件,輸入數據條目名稱。
  • 自動生成數據條目文件:在對象類型JSON文件右鍵Generate Data Entry輸入數據條目自定義名稱。

無論選擇哪種創建數據條目的方法,DevEco Studio會自動初始化已配置的對象類型,并賦初始值,同時配置數據條目所在存儲區名稱,如代碼中的cloudDBZoneName,可自定義。

{
"cloudDBZoneName": "cloudDBZoneSplash",
"objectTypeName": "splash",
"objects": [
{
"id": 1,
"timer": 3,
"isLogo": false,
"backgroundImg": "https://img1.baidu.com/it/u=1884825806,3687074543&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=889",
"companyName": "xxxx有限公司",
"mFontColor": "#F2F2F2",
"status": 0,
"createUser": 1,
"createTime": 1677035025264
},
{
"id": 2,
"timer": 3,
"isLogo": true,
"backgroundImg": "https://img1.baidu.com/it/u=1884825806,3687074543&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=889",
"companyName": "xxxx有限公司",
"mFontColor": "#F2F2F",
"status": 1,
"createUser": 1,
"createTime": 1677035025264
}
]
}

(3)部署云數據庫

在DevEco Studio還未實現端云協同開發之前,要實現云側數據庫需要在網頁端配置。當前開發者只需要在DevEco Studio云側工程中配置好云數據庫信息后,右鍵clouddb目錄選擇Deploy Cloud DB將云數據庫需要的資源統一部署到AGC控制臺,Event Log會顯示同步進度信息。部署完成后,可在AGC控制臺查看部署的云數據庫信息。

DevEco Studio端云協同開發之云數據庫體驗-開源基礎軟件社區

2、端側Application訪問云側數據庫業務實現

使用端云協同開發,將較于之前的操作會減少如配置開發環境agconnect-services.json文件引入,該文件在創建端云協同工程時會自動初始化到工程中,在entry/src/main/resources/rawfile中;同時會自動引入相關依賴文件,如database-ohos等。

除配置文件和依賴文件之外,還需要和之前的操作相同,導出JSON格式文件和JS格式文件并添加至本地開發環境中。

(1)添加對象類型文件

  • 將導出的數據類型JSON文件內容拷貝到entry/src/main/ets/services/app-schema.json中,若無該文件則創建即可。
  • 將導出的JS格式文件拷貝到entry/src/main/ets/services/目錄下。

(2)云數據庫操作

該文件僅作為示例應用獲取云數據庫數據,若需要更詳細的開發者可自定義封裝,其中異常并未作處理,開發者可根據自身業務做響應的處理。

// entry/src/main/ets/services/CloudDBService.ts
// @ts-ignore
import * as schema from './app-schema.json';
import { splash } from './splash';
import {
AGConnectCloudDB,
CloudDBZoneConfig,
CloudDBZone,
CloudDBZoneQuery
} from '@hw-agconnect/database-ohos';

import { AGCRoutePolicy } from '@hw-agconnect/core-ohos';

import { getAGConnect } from './AgcConfig';

export class CloudDBService {

private static readonly ZONE_NAME = "cloudDBZoneSplash";

private static init(context: any): Promise<CloudDBZone> {
return new Promise((resolve, reject) => {
getAGConnect(context);
AGConnectCloudDB.initialize(context);
AGConnectCloudDB.getInstance({
context: context,
agcRoutePolicy: AGCRoutePolicy.CHINA,
objectTypeInfo: schema
}).then((ret) => {
return resolve(ret.openCloudDBZone(this.ZONE_NAME));
});
})
}
// 查詢狀態為'1'的啟動頁信息
public static query(context: any): Promise<splash> {
return new Promise((resolve, reject) => {
const query = CloudDBZoneQuery.where(splash).equalTo("status", 1);
this.init(context).then((ret) => {
ret.executeQuery(query).then((ret) => {
resolve(ret.getSnapshotObjects()[0]);
})
});
})
}
}

(3)將云數據庫數據渲染到頁面

利用aboutToAppear()方法獲取云數據庫中的啟動頁信息。

import { CloudDBService as CloudDB } from '../services/CloudDBService';
import { SplashPage } from '@tetcl/teui';
@Entry
@Component
struct Splash {

@State result: SplashObj = new SplashObj(5);
@State isSkip: boolean = false;

onSkipt() {
// 跳轉頁面
}

build() {
Column() {
if (this.isSkip) {
SplashPage({ mSplash: {
timer: this.result.timer,
isLogo: this.result.isLogo,
backgroundImg: this.result.backgroundImg,
companyName: this.result.companyName,
mFontColor: this.result.mFontColor
}, skip: this.onSkip })
}
}
.width('100%')
.height('100%')
}

aboutToAppear() {
// 若受網絡印象獲取數據時間過長,此處可以自定義一個數據加載動畫
CloudDB.query(getContext(this)).then(ret => {
this.isSkip = true;
this.result = ret;
})
}
}

3、在開發板預覽效果

DevEco Studio端云協同開發之云數據庫體驗-開源基礎軟件社區

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

責任編輯:jianghua 來源: 51CTO 開源基礎軟件社區
相關推薦

2023-03-02 20:46:32

鴻蒙云存儲服務

2023-02-20 10:15:00

云協同邊緣

2010-11-16 09:12:42

SQL Azure

2016-03-14 13:56:56

華為/合作伙伴大會

2011-08-03 09:33:48

云數據庫云服務云計算

2023-03-15 16:24:43

云數據庫代碼開發

2020-06-22 14:19:28

小程序云開發數據庫

2011-07-29 13:23:41

神通云庫數據庫

2023-07-10 16:01:17

云數據庫存儲

2012-02-14 09:00:56

數據庫云計算

2011-12-24 14:08:18

云計算數據庫云服務

2010-10-09 10:34:12

SQL Azure云數

2022-05-09 15:54:44

平安科技TiDB云原生

2022-11-14 18:23:06

亞馬遜

2022-03-07 10:27:21

云原生云計算數據庫

2023-01-26 00:18:53

云原生數據庫云資源

2022-10-27 15:57:26

開發工具鴻蒙

2015-07-14 17:12:49

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: www4虎 | 草草视频在线观看 | 尤物视频在线免费观看 | 日韩精品一区二区三区中文在线 | 国产不卡一区在线观看 | 欧美一区二区三区在线观看 | 免费网站国产 | 中文字幕乱码一区二区三区 | 欧美在线视频观看 | 欧美中文字幕 | 国产三级大片 | 久久精品国产免费一区二区三区 | 久久国产一区二区三区 | 一区在线视频 | 天天综合久久 | 久久国产精品91 | www.日本在线| 综合久久综合久久 | 99精品国产一区二区青青牛奶 | 国产精品视频偷伦精品视频 | 激情久久久久 | 欧美国产日韩一区二区三区 | 中国美女av | 欧美v片| 毛片免费观看 | 99久久精品国产一区二区三区 | 中文字幕男人的天堂 | 日日想夜夜操 | 久在线| 91成人免费观看 | 男女羞羞视频在线看 | 亚洲美女av网站 | 日韩精品一区中文字幕 | 日韩精品福利 | 日本一区二区三区精品视频 | 日韩在线精品视频 | 在线看亚洲 | 亚洲欧美在线观看视频 | 水蜜桃久久夜色精品一区 | 亚洲精品视频一区 | 一级一片在线观看 |