关系型数据库
关系型数据库(Relational Database,RDB)是一种基于关系模型来管理数据的数据库。关系型数据库基于SQLite组件提供了一套完整的对本地数据库进行管理的机制,对外提供了一系列的增、删、改、查等接口,也可以直接运行用户输入的SQL语句来满足复杂的场景需要。不支持Worker线程。
该模块提供以下关系型数据库相关的常用功能:
- RdbPredicates: 数据库中用来代表数据实体的性质、特征或者数据实体之间关系的词项,主要用来定义数据库的操作条件。
- RdbStore:提供管理关系数据库(RDB)方法的接口。
- ResultSet:提供用户调用关系型数据库查询接口之后返回的结果集合。
- 本模块首批接口从API version 9开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
- 关系型数据库当前仅支持本地功能,分布式功能暂不支持。
relationalStore.getRdbStore
getRdbStore(context: Context, config: StoreConfig, callback: AsyncCallback<RdbStore>): void
获得一个相关的RdbStore,操作关系型数据库,用户可以根据自己的需求配置RdbStore的参数,然后通过RdbStore调用相关接口可以执行相关的数据操作,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800010 | If failed delete database by invalid database name. |
14800011 | If failed open database by database corrupted. |
示例:
FA模型示例:
- import featureAbility from '@ohos.ability.featureAbility'
- var store;
- // 获取context
- let context = featureAbility.getContext();
- const STORE_CONFIG = {
- name: "RdbTest.db",
- securityLevel: relationalStore.SecurityLevel.S1
- };
- relationalStore.getRdbStore(context, STORE_CONFIG, function (err, rdbStore) {
- store = rdbStore;
- if (err) {
- console.error(`Get RdbStore failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Get RdbStore successfully.`);
- })
Stage模型示例:
- import UIAbility from '@ohos.app.ability.UIAbility'
- class EntryAbility extends UIAbility {
- onWindowStageCreate(windowStage) {
- var store;
- const STORE_CONFIG = {
- name: "RdbTest.db",
- securityLevel: relationalStore.SecurityLevel.S1
- };
- relationalStore.getRdbStore(this.context, STORE_CONFIG, function (err, rdbStore) {
- store = rdbStore;
- if (err) {
- console.error(`Get RdbStore failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Get RdbStore successfully.`);
- })
- }
- }
relationalStore.getRdbStore
getRdbStore(context: Context, config: StoreConfig): Promise<RdbStore>
获得一个相关的RdbStore,操作关系型数据库,用户可以根据自己的需求配置RdbStore的参数,然后通过RdbStore调用相关接口可以执行相关的数据操作,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
返回值:
类型 | 说明 |
---|---|
Promise<RdbStore> | Promise对象。返回RdbStore对象。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800010 | If failed delete database by invalid database name. |
14800011 | If failed open database by database corrupted. |
示例:
FA模型示例:
- import featureAbility from '@ohos.ability.featureAbility'
- var store;
- // 获取context
- let context = featureAbility.getContext();
- const STORE_CONFIG = {
- name: "RdbTest.db",
- securityLevel: relationalStore.SecurityLevel.S1
- };
- let promise = relationalStore.getRdbStore(context, STORE_CONFIG);
- promise.then(async (rdbStore) => {
- store = rdbStore;
- console.info(`Get RdbStore successfully.`);
- }).catch((err) => {
- console.error(`Get RdbStore failed, code is ${err.code},message is ${err.message}`);
- })
Stage模型示例:
- import UIAbility from '@ohos.app.ability.UIAbility'
- class EntryAbility extends UIAbility {
- onWindowStageCreate(windowStage) {
- var store;
- const STORE_CONFIG = {
- name: "RdbTest.db",
- securityLevel: relationalStore.SecurityLevel.S1
- };
- let promise = relationalStore.getRdbStore(this.context, STORE_CONFIG);
- promise.then(async (rdbStore) => {
- store = rdbStore;
- console.info(`Get RdbStore successfully.`)
- }).catch((err) => {
- console.error(`Get RdbStore failed, code is ${err.code},message is ${err.message}`);
- })
- }
- }
relationalStore.deleteRdbStore
deleteRdbStore(context: Context, name: string, callback: AsyncCallback<void>): void
删除数据库,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800010 | If failed delete database by invalid database name. |
示例:
FA模型示例:
- import featureAbility from '@ohos.ability.featureAbility'
- // 获取context
- let context = featureAbility.getContext()
- relationalStore.deleteRdbStore(context, "RdbTest.db", function (err) {
- if (err) {
- console.error(`Delete RdbStore failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Delete RdbStore successfully.`);
- })
Stage模型示例:
- import UIAbility from '@ohos.app.ability.UIAbility'
- class EntryAbility extends UIAbility {
- onWindowStageCreate(windowStage){
- relationalStore.deleteRdbStore(this.context, "RdbTest.db", function (err) {
- if (err) {
- console.error(`Delete RdbStore failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Delete RdbStore successfully.`);
- })
- }
- }
relationalStore.deleteRdbStore
deleteRdbStore(context: Context, name: string): Promise<void>
使用指定的数据库文件配置删除数据库,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数
返回值:
类型 | 说明 |
---|---|
Promise<void> | 无返回结果的Promise对象。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800010 | If failed delete database by invalid database name. |
示例:
FA模型示例:
- import featureAbility from '@ohos.ability.featureAbility'
- // 获取context
- let context = featureAbility.getContext();
- let promise = relationalStore.deleteRdbStore(context, "RdbTest.db");
- promise.then(()=>{
- console.info(`Delete RdbStore successfully.`);
- }).catch((err) => {
- console.error(`Delete RdbStore failed, code is ${err.code},message is ${err.message}`);
- })
Stage模型示例:
- import UIAbility from '@ohos.app.ability.UIAbility'
- class EntryAbility extends UIAbility {
- onWindowStageCreate(windowStage){
- let promise = relationalStore.deleteRdbStore(this.context, "RdbTest.db");
- promise.then(()=>{
- console.info(`Delete RdbStore successfully.`);
- }).catch((err) => {
- console.error(`Delete RdbStore failed, code is ${err.code},message is ${err.message}`);
- })
- }
- }
StoreConfig
管理关系数据库配置。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
名称 | 类型 | 必填 | 说明 |
---|---|---|---|
name | string | 是 | 数据库文件名。 |
securityLevel | 是 | 设置数据库安全级别 | |
encrypt | boolean | 否 | 指定数据库是否加密,默认不加密。 true:加密。 false:非加密。 |
SecurityLevel
数据库的安全级别枚举。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
名称 | 值 | 说明 |
---|---|---|
S1 | 1 | 表示数据库的安全级别为低级别,当数据泄露时会产生较低影响。例如,包含壁纸等系统数据的数据库。 |
S2 | 2 | 表示数据库的安全级别为中级别,当数据泄露时会产生较大影响。例如,包含录音、视频等用户生成数据或通话记录等信息的数据库。 |
S3 | 3 | 表示数据库的安全级别为高级别,当数据泄露时会产生重大影响。例如,包含用户运动、健康、位置等信息的数据库。 |
S4 | 4 | 表示数据库的安全级别为关键级别,当数据泄露时会产生严重影响。例如,包含认证凭据、财务数据等信息的数据库。 |
ValueType
用于表示允许的数据字段类型。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
类型 | 说明 |
---|---|
number | 表示值类型为数字。 |
string | 表示值类型为字符。 |
boolean | 表示值类型为布尔值。 |
ValuesBucket
用于存储键值对的类型。该类型不是多线程安全的,如果应用中存在多线程同时操作该类派生出的实例,注意加锁保护。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
键类型 | 值类型 |
---|---|
string | ValueType| Uint8Array | null |
SyncMode
指数据库同步模式。
当前HarmonyOS设备均不支持此接口,此接口在被sync()接口调用时将返回801错误码。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
名称 | 值 | 说明 |
---|---|---|
SYNC_MODE_PUSH | 0 | 表示数据从本地设备推送到远程设备。 |
SYNC_MODE_PULL | 1 | 表示数据从远程设备拉至本地设备。 |
SubscribeType
描述订阅类型。
当前HarmonyOS设备均不支持此接口,此接口在被on('dataChange')、off('dataChange')接口调用时将返回801错误码。
需要权限: ohos.permission.DISTRIBUTED_DATASYNC
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
名称 | 值 | 说明 |
---|---|---|
SUBSCRIBE_TYPE_REMOTE | 0 | 订阅远程数据更改。 |
RdbPredicates
表示关系型数据库(RDB)的谓词。该类确定RDB中条件表达式的值是true还是false。该类型不是多线程安全的,如果应用中存在多线程同时操作该类派生出的实例,注意加锁保护。
constructor
constructor(name: string)
构造函数。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
name | string | 是 | 数据库表名。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
inDevices
inDevices(devices: Array<string>): RdbPredicates
同步分布式数据库时连接到组网内指定的远程设备。
当前HarmonyOS设备均不支持此接口,应用调用此接口后再调用remoteQuery()接口将返回801错误码。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
devices | Array<string> | 是 | 指定的组网内的远程设备ID。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.inDevices(['12345678abcde']);
inAllDevices
inAllDevices(): RdbPredicates
同步分布式数据库时连接到组网内所有的远程设备。
当前HarmonyOS设备均不支持此接口,应用调用此接口后再调用remoteQuery()接口将返回801错误码。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.inAllDevices();
equalTo
equalTo(field: string, value: ValueType): RdbPredicates
配置谓词以匹配数据表的field列中值为value的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | 是 | 指示要与谓词匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "lisi");
notEqualTo
notEqualTo(field: string, value: ValueType): RdbPredicates
配置谓词以匹配数据表的field列中值不为value的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | 是 | 指示要与谓词匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.notEqualTo("NAME", "lisi");
beginWrap
beginWrap(): RdbPredicates
向谓词添加左括号。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
返回值:
类型 | 说明 |
---|---|
返回带有左括号的Rdb谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "lisi")
- .beginWrap()
- .equalTo("AGE", 18)
- .or()
- .equalTo("SALARY", 200.5)
- .endWrap()
endWrap
endWrap(): RdbPredicates
向谓词添加右括号。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
返回值:
类型 | 说明 |
---|---|
返回带有右括号的Rdb谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "lisi")
- .beginWrap()
- .equalTo("AGE", 18)
- .or()
- .equalTo("SALARY", 200.5)
- .endWrap()
or
or(): RdbPredicates
将或条件添加到谓词中。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
返回值:
类型 | 说明 |
---|---|
返回带有或条件的Rdb谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Lisa")
- .or()
- .equalTo("NAME", "Rose")
and
and(): RdbPredicates
向谓词添加和条件。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
返回值:
类型 | 说明 |
---|---|
返回带有和条件的Rdb谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Lisa")
- .and()
- .equalTo("SALARY", 200.5)
contains
contains(field: string, value: string): RdbPredicates
配置谓词以匹配数据表的field列中包含value的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | string | 是 | 指示要与谓词匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.contains("NAME", "os");
beginsWith
beginsWith(field: string, value: string): RdbPredicates
配置谓词以匹配数据表的field列中以value开头的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | string | 是 | 指示要与谓词匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.beginsWith("NAME", "os");
endsWith
endsWith(field: string, value: string): RdbPredicates
配置谓词以匹配数据表的field列中以value结尾的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | string | 是 | 指示要与谓词匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.endsWith("NAME", "se");
isNull
isNull(field: string): RdbPredicates
配置谓词以匹配数据表的field列中值为null的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.isNull("NAME");
isNotNull
isNotNull(field: string): RdbPredicates
配置谓词以匹配数据表的field列中值不为null的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.isNotNull("NAME");
like
like(field: string, value: string): RdbPredicates
配置谓词以匹配数据表的field列中值类似于value的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | string | 是 | 指示要与谓词匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.like("NAME", "%os%");
glob
glob(field: string, value: string): RdbPredicates
配置谓词匹配数据字段为string的指定字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | string | 是 | 指示要与谓词匹配的值。 支持通配符,*表示0个、1个或多个数字或字符,?表示1个数字或字符。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.glob("NAME", "?h*g");
between
between(field: string, low: ValueType, high: ValueType): RdbPredicates
配置谓词以匹配数据表的field列中值在给定范围内的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.between("AGE", 10, 50);
notBetween
notBetween(field: string, low: ValueType, high: ValueType): RdbPredicates
配置谓词以匹配数据表的field列中值超出给定范围的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.notBetween("AGE", 10, 50);
greaterThan
greaterThan(field: string, value: ValueType): RdbPredicates
配置谓词以匹配数据表的field列中值大于value的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | 是 | 指示要与谓词匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.greaterThan("AGE", 18);
lessThan
lessThan(field: string, value: ValueType): RdbPredicates
配置谓词以匹配数据表的field列中值小于value的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | 是 | 指示要与谓词匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.lessThan("AGE", 20);
greaterThanOrEqualTo
greaterThanOrEqualTo(field: string, value: ValueType): RdbPredicates
配置谓词以匹配数据表的field列中值大于或者等于value的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | 是 | 指示要与谓词匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.greaterThanOrEqualTo("AGE", 18);
lessThanOrEqualTo
lessThanOrEqualTo(field: string, value: ValueType): RdbPredicates
配置谓词以匹配数据表的field列中值小于或者等于value的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | 是 | 指示要与谓词匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.lessThanOrEqualTo("AGE", 20);
orderByAsc
orderByAsc(field: string): RdbPredicates
配置谓词以匹配数据表的field列中值按升序排序的列。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.orderByAsc("NAME");
orderByDesc
orderByDesc(field: string): RdbPredicates
配置谓词以匹配数据表的field列中值按降序排序的列。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.orderByDesc("AGE");
distinct
distinct(): RdbPredicates
配置谓词以过滤重复记录并仅保留其中一个。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
返回值:
类型 | 说明 |
---|---|
返回可用于过滤重复记录的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Rose").distinct();
limitAs
limitAs(value: number): RdbPredicates
设置最大数据记录数的谓词。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
value | number | 是 | 最大数据记录数。 |
返回值:
类型 | 说明 |
---|---|
返回可用于设置最大数据记录数的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Rose").limitAs(3);
offsetAs
offsetAs(rowOffset: number): RdbPredicates
配置谓词以指定返回结果的起始位置。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
rowOffset | number | 是 | 返回结果的起始位置,取值为正整数。 |
返回值:
类型 | 说明 |
---|---|
返回具有指定返回结果起始位置的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Rose").offsetAs(3);
groupBy
groupBy(fields: Array<string>): RdbPredicates
配置谓词按指定列分组查询结果。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
fields | Array<string> | 是 | 指定分组依赖的列名。 |
返回值:
类型 | 说明 |
---|---|
返回分组查询列的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.groupBy(["AGE", "NAME"]);
indexedBy
indexedBy(field: string): RdbPredicates
配置谓词以指定索引列。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 索引列的名称。 |
返回值:
类型 | 说明 |
---|---|
返回具有指定索引列的RdbPredicates。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.indexedBy("SALARY_INDEX");
in
in(field: string, value: Array<ValueType>): RdbPredicates
配置谓词以匹配数据表的field列中值在给定范围内的字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | Array<ValueType> | 是 | 以ValueType型数组形式指定的要匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.in("AGE", [18, 20]);
notIn
notIn(field: string, value: Array<ValueType>): RdbPredicates
将谓词配置为匹配数据字段为ValueType且值超出给定范围的指定字段。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
field | string | 是 | 数据库表中的列名。 |
value | Array<ValueType> | 是 | 以ValueType数组形式指定的要匹配的值。 |
返回值:
类型 | 说明 |
---|---|
返回与指定字段匹配的谓词。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.notIn("NAME", ["Lisa", "Rose"]);
insert
insert(table: string, values: ValuesBucket, callback: AsyncCallback<number>):void
向目标表中插入一行数据,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
table | string | 是 | 指定的目标表名。 |
values | 是 | 表示要插入到表中的数据行。 | |
callback | AsyncCallback<number> | 是 | 指定callback回调函数。如果操作成功,返回行ID;否则返回-1。 |
示例:
- const valueBucket = {
- "NAME": "Lisa",
- "AGE": 18,
- "SALARY": 100.5,
- "CODES": new Uint8Array([1, 2, 3, 4, 5]),
- };
- store.insert("EMPLOYEE", valueBucket, function (err, rowId) {
- if (err) {
- console.error(`Insert is failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Insert is successful, rowId = ${rowId}`);
- })
insert
insert(table: string, values: ValuesBucket):Promise<number>
向目标表中插入一行数据,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
table | string | 是 | 指定的目标表名。 |
values | 是 | 表示要插入到表中的数据行。 |
返回值:
类型 | 说明 |
---|---|
Promise<number> | Promise对象。如果操作成功,返回行ID;否则返回-1。 |
示例:
- const valueBucket = {
- "NAME": "Lisa",
- "AGE": 18,
- "SALARY": 100.5,
- "CODES": new Uint8Array([1, 2, 3, 4, 5]),
- };
- let promise = store.insert("EMPLOYEE", valueBucket);
- promise.then((rowId) => {
- console.info(`Insert is successful, rowId = ${rowId}`);
- }).catch((err) => {
- console.error(`Insert is failed, code is ${err.code},message is ${err.message}`);
- })
batchInsert
batchInsert(table: string, values: Array<ValuesBucket>, callback: AsyncCallback<number>):void
向目标表中插入一组数据,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
table | string | 是 | 指定的目标表名。 |
values | Array<ValuesBucket> | 是 | 表示要插入到表中的一组数据。 |
callback | AsyncCallback<number> | 是 | 指定callback回调函数。如果操作成功,返回插入的数据个数,否则返回-1。 |
示例:
- const valueBucket1 = {
- "NAME": "Lisa",
- "AGE": 18,
- "SALARY": 100.5,
- "CODES": new Uint8Array([1, 2, 3, 4, 5])
- };
- const valueBucket2 = {
- "NAME": "Jack",
- "AGE": 19,
- "SALARY": 101.5,
- "CODES": new Uint8Array([6, 7, 8, 9, 10])
- };
- const valueBucket3 = {
- "NAME": "Tom",
- "AGE": 20,
- "SALARY": 102.5,
- "CODES": new Uint8Array([11, 12, 13, 14, 15])
- };
- let valueBuckets = new Array(valueBucket1, valueBucket2, valueBucket3);
- store.batchInsert("EMPLOYEE", valueBuckets, function(err, insertNum) {
- if (err) {
- console.error(`batchInsert is failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`batchInsert is successful, the number of values that were inserted = ${insertNum}`);
- })
batchInsert
batchInsert(table: string, values: Array<ValuesBucket>):Promise<number>
向目标表中插入一组数据,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
table | string | 是 | 指定的目标表名。 |
values | Array<ValuesBucket> | 是 | 表示要插入到表中的一组数据。 |
返回值:
类型 | 说明 |
---|---|
Promise<number> | Promise对象。如果操作成功,返回插入的数据个数,否则返回-1。 |
示例:
- const valueBucket1 = {
- "NAME": "Lisa",
- "AGE": 18,
- "SALARY": 100.5,
- "CODES": new Uint8Array([1, 2, 3, 4, 5])
- };
- const valueBucket2 = {
- "NAME": "Jack",
- "AGE": 19,
- "SALARY": 101.5,
- "CODES": new Uint8Array([6, 7, 8, 9, 10])
- };
- const valueBucket3 = {
- "NAME": "Tom",
- "AGE": 20,
- "SALARY": 102.5,
- "CODES": new Uint8Array([11, 12, 13, 14, 15])
- };
- let valueBuckets = new Array(valueBucket1, valueBucket2, valueBucket3);
- let promise = store.batchInsert("EMPLOYEE", valueBuckets);
- promise.then((insertNum) => {
- console.info(`batchInsert is successful, the number of values that were inserted = ${insertNum}`);
- }).catch((err) => {
- console.error(`batchInsert is failed, code is ${err.code},message is ${err.message}`);
- })
update
update(values: ValuesBucket, predicates: RdbPredicates, callback: AsyncCallback<number>):void
根据RdbPredicates的指定实例对象更新数据库中的数据,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
values | 是 | values指示数据库中要更新的数据行。键值对与数据库表的列名相关联。 | |
predicates | 是 | RdbPredicates的实例对象指定的更新条件。 | |
callback | AsyncCallback<number> | 是 | 指定的callback回调方法。返回受影响的行数。 |
示例:
- const valueBucket = {
- "NAME": "Rose",
- "AGE": 22,
- "SALARY": 200.5,
- "CODES": new Uint8Array([1, 2, 3, 4, 5]),
- };
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Lisa");
- store.update(valueBucket, predicates, function (err, rows) {
- if (err) {
- console.error(`Updated failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Updated row count: ${rows}`);
- })
update
update(values: ValuesBucket, predicates: RdbPredicates):Promise<number>
根据RdbPredicates的指定实例对象更新数据库中的数据,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
values | 是 | values指示数据库中要更新的数据行。键值对与数据库表的列名相关联。 | |
predicates | 是 | RdbPredicates的实例对象指定的更新条件。 |
返回值:
类型 | 说明 |
---|---|
Promise<number> | 指定的Promise回调方法。返回受影响的行数。 |
示例:
- const valueBucket = {
- "NAME": "Rose",
- "AGE": 22,
- "SALARY": 200.5,
- "CODES": new Uint8Array([1, 2, 3, 4, 5]),
- };
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Lisa");
- let promise = store.update(valueBucket, predicates);
- promise.then(async (rows) => {
- console.info(`Updated row count: ${rows}`);
- }).catch((err) => {
- console.error(`Updated failed, code is ${err.code},message is ${err.message}`);
- })
delete
delete(predicates: RdbPredicates, callback: AsyncCallback<number>):void
根据RdbPredicates的指定实例对象从数据库中删除数据,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
predicates | 是 | RdbPredicates的实例对象指定的删除条件。 | |
callback | AsyncCallback<number> | 是 | 指定callback回调函数。返回受影响的行数。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Lisa");
- store.delete(predicates, function (err, rows) {
- if (err) {
- console.error(`Delete failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Delete rows: ${rows}`);
- })
delete
delete(predicates: RdbPredicates):Promise<number>
根据RdbPredicates的指定实例对象从数据库中删除数据,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
predicates | 是 | RdbPredicates的实例对象指定的删除条件。 |
返回值:
类型 | 说明 |
---|---|
Promise<number> | Promise对象。返回受影响的行数。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Lisa");
- let promise = store.delete(predicates);
- promise.then((rows) => {
- console.info(`Delete rows: ${rows}`);
- }).catch((err) => {
- console.error(`Delete failed, code is ${err.code},message is ${err.message}`);
- })
query
query(predicates: RdbPredicates, columns: Array<string>, callback: AsyncCallback<ResultSet>):void
根据指定条件查询数据库中的数据,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
predicates | 是 | RdbPredicates的实例对象指定的查询条件。 | |
columns | Array<string> | 是 | 表示要查询的列。如果值为空,则查询应用于所有列。 |
callback | AsyncCallback<ResultSet> | 是 | 指定callback回调函数。如果操作成功,则返回ResultSet对象。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Rose");
- store.query(predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"], function (err, resultSet) {
- if (err) {
- console.error(`Query failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`ResultSet column names: ${resultSet.columnNames}`);
- console.info(`ResultSet column count: ${resultSet.columnCount}`);
- })
query
query(predicates: RdbPredicates, columns?: Array<string>):Promise<ResultSet>
根据指定条件查询数据库中的数据,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
predicates | 是 | RdbPredicates的实例对象指定的查询条件。 | |
columns | Array<string> | 否 | 表示要查询的列。如果值为空,则查询应用于所有列。 |
返回值:
类型 | 说明 |
---|---|
Promise<ResultSet> | Promise对象。如果操作成功,则返回ResultSet对象。 |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("NAME", "Rose");
- let promise = store.query(predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"]);
- promise.then((resultSet) => {
- console.info(`ResultSet column names: ${resultSet.columnNames}`);
- console.info(`ResultSet column count: ${resultSet.columnCount}`);
- }).catch((err) => {
- console.error(`Query failed, code is ${err.code},message is ${err.message}`);
- })
remoteQuery
remoteQuery(device: string, table: string, predicates: RdbPredicates, columns: Array<string> , callback: AsyncCallback<ResultSet>): void
根据指定条件查询远程设备数据库中的数据。使用callback异步回调。
当前HarmonyOS设备均不支持此接口,应用调用此接口将返回801错误码。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
device | string | 是 | 指定的远程设备的networkId。 |
table | string | 是 | 指定的目标表名。 |
predicates | 是 | RdbPredicates的实例对象,指定查询的条件。 | |
columns | Array<string> | 是 | 表示要查询的列。如果值为空,则查询应用于所有列。 |
callback | AsyncCallback<ResultSet> | 是 | 指定callback回调函数。如果操作成功,则返回ResultSet对象。 |
示例:
- let predicates = new relationalStore.RdbPredicates('EMPLOYEE');
- predicates.greaterThan("id", 0);
- store.remoteQuery("deviceId", "EMPLOYEE", predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"],
- function(err, resultSet) {
- if (err) {
- console.error(`Failed to remoteQuery, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`ResultSet column names: ${resultSet.columnNames}`);
- console.info(`ResultSet column count: ${resultSet.columnCount}`);
- }
- )
remoteQuery
remoteQuery(device: string, table: string, predicates: RdbPredicates, columns: Array<string>): Promise<ResultSet>
根据指定条件查询远程设备数据库中的数据。使用Promise异步回调。
当前HarmonyOS设备均不支持此接口,应用调用此接口将返回801错误码。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
device | string | 是 | 指定的远程设备的networkId。 |
table | string | 是 | 指定的目标表名。 |
predicates | 是 | RdbPredicates的实例对象,指定查询的条件。 | |
columns | Array<string> | 是 | 表示要查询的列。如果值为空,则查询应用于所有列。 |
返回值:
类型 | 说明 |
---|---|
Promise<ResultSet> | Promise对象。如果操作成功,则返回ResultSet对象。 |
示例:
- let predicates = new relationalStore.RdbPredicates('EMPLOYEE');
- predicates.greaterThan("id", 0);
- let promise = store.remoteQuery("deviceId", "EMPLOYEE", predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"]);
- promise.then((resultSet) => {
- console.info(`ResultSet column names: ${resultSet.columnNames}`);
- console.info(`ResultSet column count: ${resultSet.columnCount}`);
- }).catch((err) => {
- console.error(`Failed to remoteQuery, code is ${err.code},message is ${err.message}`);
- })
querySql
querySql(sql: string, bindArgs: Array<ValueType>, callback: AsyncCallback<ResultSet>):void
根据指定SQL语句查询数据库中的数据,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
示例:
- store.querySql("SELECT * FROM EMPLOYEE CROSS JOIN BOOK WHERE BOOK.NAME = ?", ['sanguo'], function (err, resultSet) {
- if (err) {
- console.error(`Query failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`ResultSet column names: ${resultSet.columnNames}`);
- console.info(`ResultSet column count: ${resultSet.columnCount}`);
- })
querySql
querySql(sql: string, bindArgs?: Array<ValueType>):Promise<ResultSet>
根据指定SQL语句查询数据库中的数据,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
sql | string | 是 | 指定要执行的SQL语句。 |
bindArgs | Array<ValueType> | 否 | SQL语句中参数的值。当sql参数语句完整时,该参数不填。 |
返回值:
类型 | 说明 |
---|---|
Promise<ResultSet> | Promise对象。如果操作成功,则返回ResultSet对象。 |
示例:
- let promise = store.querySql("SELECT * FROM EMPLOYEE CROSS JOIN BOOK WHERE BOOK.NAME = 'sanguo'");
- promise.then((resultSet) => {
- console.info(`ResultSet column names: ${resultSet.columnNames}`);
- console.info(`ResultSet column count: ${resultSet.columnCount}`);
- }).catch((err) => {
- console.error(`Query failed, code is ${err.code},message is ${err.message}`);
- })
executeSql
executeSql(sql: string, bindArgs: Array<ValueType>, callback: AsyncCallback<void>):void
执行包含指定参数但不返回值的SQL语句,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
sql | string | 是 | 指定要执行的SQL语句。 |
bindArgs | Array<ValueType> | 是 | SQL语句中参数的值。该值与sql参数语句中的占位符相对应。当sql参数语句完整时,该参数需为空数组。 |
callback | AsyncCallback<void> | 是 | 指定callback回调函数。 |
示例:
- const SQL_DELETE_TABLE = "DELETE FROM test WHERE name = ?"
- store.executeSql(SQL_DELETE_TABLE, ['zhangsan'], function(err) {
- if (err) {
- console.error(`ExecuteSql failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Delete table done.`);
- })
executeSql
executeSql(sql: string, bindArgs?: Array<ValueType>):Promise<void>
执行包含指定参数但不返回值的SQL语句,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
sql | string | 是 | 指定要执行的SQL语句。 |
bindArgs | Array<ValueType> | 否 | SQL语句中参数的值。当sql参数语句完整时,该参数不填。 |
返回值:
类型 | 说明 |
---|---|
Promise<void> | 无返回结果的Promise对象。 |
示例:
- const SQL_DELETE_TABLE = "DELETE FROM test WHERE name = 'zhangsan'"
- let promise = store.executeSql(SQL_DELETE_TABLE);
- promise.then(() => {
- console.info(`Delete table done.`);
- }).catch((err) => {
- console.error(`ExecuteSql failed, code is ${err.code},message is ${err.message}`);
- })
beginTransaction
beginTransaction():void
在开始执行SQL语句之前,开始事务。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
示例:
- import featureAbility from '@ohos.ability.featureAbility'
- let context = featureAbility.getContext();
- const STORE_CONFIG = {
- name: "RdbTest.db",
- securityLevel: relationalStore.SecurityLevel.S1
- };
- relationalStore.getRdbStore(context, STORE_CONFIG, async function (err, store) {
- if (err) {
- console.error(`GetRdbStore failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- store.beginTransaction();
- const valueBucket = {
- "name": "lisi",
- "age": 18,
- "salary": 100.5,
- "blobType": new Uint8Array([1, 2, 3]),
- };
- await store.insert("test", valueBucket);
- store.commit();
- })
commit
commit():void
提交已执行的SQL语句。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
示例:
- import featureAbility from '@ohos.ability.featureAbility'
- let context = featureAbility.getContext();
- const STORE_CONFIG = {
- name: "RdbTest.db",
- securityLevel: relationalStore.SecurityLevel.S1
- };
- relationalStore.getRdbStore(context, STORE_CONFIG, async function (err, store) {
- if (err) {
- console.error(`GetRdbStore failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- store.beginTransaction();
- const valueBucket = {
- "name": "lisi",
- "age": 18,
- "salary": 100.5,
- "blobType": new Uint8Array([1, 2, 3]),
- };
- await store.insert("test", valueBucket);
- store.commit();
- })
rollBack
rollBack():void
回滚已经执行的SQL语句。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
示例:
- import featureAbility from '@ohos.ability.featureAbility'
- let context = featureAbility.getContext();
- const STORE_CONFIG = {
- name: "RdbTest.db",
- securityLevel: relationalStore.SecurityLevel.S1
- };
- relationalStore.getRdbStore(context, STORE_CONFIG, async function (err, store) {
- if (err) {
- console.error(`GetRdbStore failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- try {
- store.beginTransaction()
- const valueBucket = {
- "id": 1,
- "name": "lisi",
- "age": 18,
- "salary": 100.5,
- "blobType": new Uint8Array([1, 2, 3]),
- };
- await store.insert("test", valueBucket);
- store.commit();
- } catch (err) {
- console.error(`Transaction failed, code is ${err.code},message is ${err.message}`);
- store.rollBack();
- }
- })
backup
backup(destName:string, callback: AsyncCallback<void>):void
以指定名称备份数据库,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
destName | string | 是 | 指定数据库的备份文件名。 |
callback | AsyncCallback<void> | 是 | 指定callback回调函数。 |
示例:
- store.backup("dbBackup.db", function(err) {
- if (err) {
- console.error(`Backup failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Backup success.`);
- })
backup
backup(destName:string): Promise<void>
以指定名称备份数据库,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
destName | string | 是 | 指定数据库的备份文件名。 |
返回值:
类型 | 说明 |
---|---|
Promise<void> | 无返回结果的Promise对象。 |
示例:
- let promiseBackup = store.backup("dbBackup.db");
- promiseBackup.then(()=>{
- console.info(`Backup success.`);
- }).catch((err)=>{
- console.error(`Backup failed, code is ${err.code},message is ${err.message}`);
- })
restore
restore(srcName:string, callback: AsyncCallback<void>):void
从指定的数据库备份文件恢复数据库,使用callback异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
srcName | string | 是 | 指定数据库的备份文件名。 |
callback | AsyncCallback<void> | 是 | 指定callback回调函数。 |
示例:
- store.restore("dbBackup.db", function(err) {
- if (err) {
- console.error(`Restore failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Restore success.`);
- })
restore
restore(srcName:string): Promise<void>
从指定的数据库备份文件恢复数据库,使用Promise异步回调。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
srcName | string | 是 | 指定数据库的备份文件名。 |
返回值:
类型 | 说明 |
---|---|
Promise<void> | 无返回结果的Promise对象。 |
示例:
- let promiseRestore = store.restore("dbBackup.db");
- promiseRestore.then(()=>{
- console.info(`Restore success.`);
- }).catch((err)=>{
- console.error(`Restore failed, code is ${err.code},message is ${err.message}`);
- })
setDistributedTables
setDistributedTables(tables: Array<string>, callback: AsyncCallback<void>): void
设置分布式列表,使用callback异步回调。
当前HarmonyOS设备均不支持此接口,应用调用此接口将返回801错误码。
需要权限: ohos.permission.DISTRIBUTED_DATASYNC
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
tables | Array<string> | 是 | 要设置的分布式列表表名 |
callback | AsyncCallback<void> | 是 | 指定callback回调函数。 |
示例:
- store.setDistributedTables(["EMPLOYEE"], function (err) {
- if (err) {
- console.error(`SetDistributedTables failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`SetDistributedTables successfully.`);
- })
setDistributedTables
setDistributedTables(tables: Array<string>): Promise<void>
设置分布式列表,使用Promise异步回调。
当前HarmonyOS设备均不支持此接口,应用调用此接口将返回801错误码。
需要权限: ohos.permission.DISTRIBUTED_DATASYNC
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
tables | Array<string> | 是 | 要设置的分布式列表表名。 |
返回值:
类型 | 说明 |
---|---|
Promise<void> | 无返回结果的Promise对象。 |
示例:
- let promise = store.setDistributedTables(["EMPLOYEE"]);
- promise.then(() => {
- console.info(`SetDistributedTables successfully.`);
- }).catch((err) => {
- console.error(`SetDistributedTables failed, code is ${err.code},message is ${err.message}`);
- })
obtainDistributedTableName
obtainDistributedTableName(device: string, table: string, callback: AsyncCallback<string>): void
根据本地表名获取指定远程设备的分布式表名。在查询远程设备数据库时,需要使用分布式表名, 使用callback异步回调。
当前HarmonyOS设备均不支持此接口,应用调用此接口将返回801错误码。
需要权限: ohos.permission.DISTRIBUTED_DATASYNC
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
device | string | 是 | 远程设备 。 |
table | string | 是 | 本地表名。 |
callback | AsyncCallback<string> | 是 | 指定的callback回调函数。如果操作成功,返回远程设备的分布式表名。 |
示例:
- store.obtainDistributedTableName("12345678abcde", "EMPLOYEE", function (err, tableName) {
- if (err) {
- console.error(`ObtainDistributedTableName failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`ObtainDistributedTableName successfully, tableName= ${tableName}`);
- })
obtainDistributedTableName
obtainDistributedTableName(device: string, table: string): Promise<string>
根据本地表名获取指定远程设备的分布式表名。在查询远程设备数据库时,需要使用分布式表名,使用Promise异步回调。
当前HarmonyOS设备均不支持此接口,应用调用此接口将返回801错误码。
需要权限: ohos.permission.DISTRIBUTED_DATASYNC
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
device | string | 是 | 远程设备。 |
table | string | 是 | 本地表名。 |
返回值:
类型 | 说明 |
---|---|
Promise<string> | Promise对象。如果操作成功,返回远程设备的分布式表名。 |
示例:
- let promise = store.obtainDistributedTableName("12345678abcde", "EMPLOYEE");
- promise.then((tableName) => {
- console.info(`ObtainDistributedTableName successfully, tableName= ${tableName}`);
- }).catch((err) => {
- console.error(`ObtainDistributedTableName failed, code is ${err.code},message is ${err.message}`);
- })
sync
sync(mode: SyncMode, predicates: RdbPredicates, callback: AsyncCallback<Array<[string, number]>>): void
在设备之间同步数据, 使用callback异步回调。
当前HarmonyOS设备均不支持此接口,应用调用此接口将返回801错误码。
需要权限: ohos.permission.DISTRIBUTED_DATASYNC
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
mode | 是 | 指同步模式。该值可以是推、拉。 | |
predicates | 是 | 约束同步数据和设备。 | |
callback | AsyncCallback<Array<[string, number]>> | 是 | 指定的callback回调函数,用于向调用者发送同步结果。string:设备ID;number:每个设备同步状态,0表示成功,其他值表示失败。 |
示例:
- let predicates = new relationalStore.RdbPredicates('EMPLOYEE');
- predicates.inDevices(['12345678abcde']);
- store.sync(relationalStore.SyncMode.SYNC_MODE_PUSH, predicates, function (err, result) {
- if (err) {
- console.error(`Sync failed, code is ${err.code},message is ${err.message}`);
- return;
- }
- console.info(`Sync done.`);
- for (let i = 0; i < result.length; i++) {
- console.info(`device= ${result[i][0]}, status= ${result[i][1]}`);
- }
- })
sync
sync(mode: SyncMode, predicates: RdbPredicates): Promise<Array<[string, number]>>
在设备之间同步数据,使用Promise异步回调。
当前HarmonyOS设备均不支持此接口,应用调用此接口将返回801错误码。
需要权限: ohos.permission.DISTRIBUTED_DATASYNC
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
mode | 是 | 指同步模式。该值可以是推、拉。 | |
predicates | 是 | 约束同步数据和设备。 |
返回值:
类型 | 说明 |
---|---|
Promise<Array<[string, number]>> | Promise对象,用于向调用者发送同步结果。string:设备ID;number:每个设备同步状态,0表示成功,其他值表示失败。 |
示例:
- let predicates = new relationalStore.RdbPredicates('EMPLOYEE');
- predicates.inDevices(['12345678abcde']);
- let promise = store.sync(relationalStore.SyncMode.SYNC_MODE_PUSH, predicates);
- promise.then((result) =>{
- console.info(`Sync done.`);
- for (let i = 0; i < result.length; i++) {
- console.info(`device= ${result[i][0]}, status= ${result[i][1]}`);
- }
- }).catch((err) => {
- console.error(`Sync failed, code is ${err.code},message is ${err.message}`);
- })
on('dataChange')
on(event: 'dataChange', type: SubscribeType, observer: Callback<Array<string>>): void
注册数据库的观察者。当分布式数据库中的数据发生更改时,将调用回调。
当前HarmonyOS设备均不支持此接口,应用调用此接口将返回801错误码。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
event | string | 是 | 取值为'dataChange',表示数据更改。 |
type | 是 | 订阅类型。 | |
observer | Callback<Array<string>> | 是 | 指分布式数据库中数据更改事件的观察者。Array<string>为数据库中的数据发生改变的对端设备ID。 |
示例:
- function storeObserver(devices) {
- for (let i = 0; i < devices.length; i++) {
- console.info(`device= ${devices[i]} data changed`);
- }
- }
- try {
- store.on('dataChange', relationalStore.SubscribeType.SUBSCRIBE_TYPE_REMOTE, storeObserver);
- } catch (err) {
- console.error(`Register observer failed, code is ${err.code},message is ${err.message}`);
- }
off('dataChange')
off(event:'dataChange', type: SubscribeType, observer: Callback<Array<string>>): void
从数据库中删除指定类型的指定观察者。
当前HarmonyOS设备均不支持此接口,应用调用此接口将返回801错误码。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
event | string | 是 | 取值为'dataChange',表示数据更改。 |
type | 是 | 订阅类型。 | |
observer | Callback<Array<string>> | 是 | 指已注册的数据更改观察者。Array<string>为数据库中的数据发生改变的对端设备ID。 |
示例:
- function storeObserver(devices) {
- for (let i = 0; i < devices.length; i++) {
- console.info(`device= ${devices[i]} data changed`);
- }
- }
- try {
- store.off('dataChange', relationalStore.SubscribeType.SUBSCRIBE_TYPE_REMOTE, storeObserver);
- } catch (err) {
- console.error(`Unregister observer failed, code is ${err.code},message is ${err.message}`);
- }
使用说明
首先需要获取resultSet对象。
- let resultSet = null;
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- predicates.equalTo("AGE", 18);
- let promise = store.query(predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"]);
- promise.then((result) => {
- resultSet = result;
- console.info(`resultSet columnNames: ${resultSet.columnNames}`);
- console.info(`resultSet columnCount: ${resultSet.columnCount}`);
- });
属性
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
名称 | 类型 | 必填 | 说明 |
---|---|---|---|
columnNames | Array<string> | 是 | 获取结果集中所有列的名称。 |
columnCount | number | 是 | 获取结果集中的列数。 |
rowCount | number | 是 | 获取结果集中的行数。 |
rowIndex | number | 是 | 获取结果集当前行的索引。 |
isAtFirstRow | boolean | 是 | 检查结果集是否位于第一行。 |
isAtLastRow | boolean | 是 | 检查结果集是否位于最后一行。 |
isEnded | boolean | 是 | 检查结果集是否位于最后一行之后。 |
isStarted | boolean | 是 | 检查指针是否移动过。 |
isClosed | boolean | 是 | 检查当前结果集是否关闭。 |
getColumnIndex
getColumnIndex(columnName: string): number
根据指定的列名获取列索引。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
columnName | string | 是 | 表示结果集中指定列的名称。 |
返回值:
类型 | 说明 |
---|---|
number | 返回指定列的索引。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800013 | The column value is null or the column type is incompatible. |
示例:
- resultSet.goToFirstRow();
- const id = resultSet.getLong(resultSet.getColumnIndex("ID"));
- const name = resultSet.getString(resultSet.getColumnIndex("NAME"));
- const age = resultSet.getLong(resultSet.getColumnIndex("AGE"));
- const salary = resultSet.getDouble(resultSet.getColumnIndex("SALARY"));
getColumnName
getColumnName(columnIndex: number): string
根据指定的列索引获取列名。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
columnIndex | number | 是 | 表示结果集中指定列的索引。 |
返回值:
类型 | 说明 |
---|---|
string | 返回指定列的名称。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800013 | The column value is null or the column type is incompatible. |
示例:
- const id = resultSet.getColumnName(0);
- const name = resultSet.getColumnName(1);
- const age = resultSet.getColumnName(2);
goTo
goTo(offset:number): boolean
向前或向后转至结果集的指定行,相对于其当前位置偏移。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
offset | number | 是 | 表示相对于当前位置的偏移量。 |
返回值:
类型 | 说明 |
---|---|
boolean | 如果成功移动结果集,则为true;否则返回false。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800012 | The result set is empty or the specified location is invalid. |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- let promise= store.query(predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"]);
- promise.then((resultSet) => {
- resultSet.goTo(1);
- resultSet.close();
- }).catch((err) => {
- console.error(`query failed, code is ${err.code},message is ${err.message}`);
- });
goToRow
goToRow(position: number): boolean
转到结果集的指定行。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
position | number | 是 | 表示要移动到的指定位置。 |
返回值:
类型 | 说明 |
---|---|
boolean | 如果成功移动结果集,则为true;否则返回false。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800012 | The result set is empty or the specified location is invalid. |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- let promise = store.query(predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"]);
- promise.then((resultSet) => {
- resultSet.goToRow(5);
- resultSet.close();
- }).catch((err) => {
- console.error(`query failed, code is ${err.code},message is ${err.message}`);
- });
goToFirstRow
goToFirstRow(): boolean
转到结果集的第一行。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
返回值:
类型 | 说明 |
---|---|
boolean | 如果成功移动结果集,则为true;否则返回false。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800012 | The result set is empty or the specified location is invalid. |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- let promise = store.query(predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"]);
- promise.then((resultSet) => {
- resultSet.goToFirstRow();
- resultSet.close();
- }).catch((err) => {
- console.error(`query failed, code is ${err.code},message is ${err.message}`);
- });
goToLastRow
goToLastRow(): boolean
转到结果集的最后一行。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
返回值:
类型 | 说明 |
---|---|
boolean | 如果成功移动结果集,则为true;否则返回false。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800012 | The result set is empty or the specified location is invalid. |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- let promise = store.query(predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"]);
- promise.then((resultSet) => {
- resultSet.goToLastRow();
- resultSet.close();
- }).catch((err) => {
- console.error(`query failed, code is ${err.code},message is ${err.message}`);
- });
goToNextRow
goToNextRow(): boolean
转到结果集的下一行。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
返回值:
类型 | 说明 |
---|---|
boolean | 如果成功移动结果集,则为true;否则返回false。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800012 | The result set is empty or the specified location is invalid. |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- let promise = store.query(predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"]);
- promise.then((resultSet) => {
- resultSet.goToNextRow();
- resultSet.close();
- }).catch((err) => {
- console.error(`query failed, code is ${err.code},message is ${err.message}`);
- });
goToPreviousRow
goToPreviousRow(): boolean
转到结果集的上一行。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
返回值:
类型 | 说明 |
---|---|
boolean | 如果成功移动结果集,则为true;否则返回false。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800012 | The result set is empty or the specified location is invalid. |
示例:
- let predicates = new relationalStore.RdbPredicates("EMPLOYEE");
- let promise = store.query(predicates, ["ID", "NAME", "AGE", "SALARY", "CODES"]);
- promise.then((resultSet) => {
- resultSet.goToPreviousRow();
- resultSet.close();
- }).catch((err) => {
- console.error(`query failed, code is ${err.code},message is ${err.message}`);
- });
getBlob
getBlob(columnIndex: number): Uint8Array
以字节数组的形式获取当前行中指定列的值。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
columnIndex | number | 是 | 指定的列索引,从0开始。 |
返回值:
类型 | 说明 |
---|---|
Uint8Array | 以字节数组的形式返回指定列的值。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800013 | The column value is null or the column type is incompatible. |
示例:
- const codes = resultSet.getBlob(resultSet.getColumnIndex("CODES"));
getString
getString(columnIndex: number): string
以字符串形式获取当前行中指定列的值。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
columnIndex | number | 是 | 指定的列索引,从0开始。 |
返回值:
类型 | 说明 |
---|---|
string | 以字符串形式返回指定列的值。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800013 | The column value is null or the column type is incompatible. |
示例:
- const name = resultSet.getString(resultSet.getColumnIndex("NAME"));
getLong
getLong(columnIndex: number): number
以Long形式获取当前行中指定列的值。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
columnIndex | number | 是 | 指定的列索引,从0开始。 |
返回值:
类型 | 说明 |
---|---|
number | 以Long形式返回指定列的值。 该接口支持的数据范围是:Number.MIN_SAFE_INTEGER ~ Number.MAX_SAFE_INTEGER,若超出该范围,建议使用getDouble。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800013 | The column value is null or the column type is incompatible. |
示例:
- const age = resultSet.getLong(resultSet.getColumnIndex("AGE"));
getDouble
getDouble(columnIndex: number): number
以double形式获取当前行中指定列的值。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
columnIndex | number | 是 | 指定的列索引,从0开始。 |
返回值:
类型 | 说明 |
---|---|
number | 以double形式返回指定列的值。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800013 | The column value is null or the column type is incompatible. |
示例:
- const salary = resultSet.getDouble(resultSet.getColumnIndex("SALARY"));
isColumnNull
isColumnNull(columnIndex: number): boolean
检查当前行中指定列的值是否为null。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
columnIndex | number | 是 | 指定的列索引,从0开始。 |
返回值:
类型 | 说明 |
---|---|
boolean | 如果当前行中指定列的值为null,则返回true,否则返回false。 |
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800013 | The column value is null or the column type is incompatible. |
示例:
- const isColumnNull = resultSet.isColumnNull(resultSet.getColumnIndex("CODES"));
close
close(): void
关闭结果集。
系统能力: SystemCapability.DistributedDataManager.RelationalStore.Core
示例:
- let predicatesClose = new relationalStore.RdbPredicates("EMPLOYEE");
- let promiseClose = store.query(predicatesClose, ["ID", "NAME", "AGE", "SALARY", "CODES"]);
- promiseClose.then((resultSet) => {
- resultSet.close();
- }).catch((err) => {
- console.error(`resultset close failed, code is ${err.code},message is ${err.message}`);
- });
错误码:
以下错误码的详细介绍请参见关系型数据库错误码。
错误码ID | 错误信息 |
---|---|
14800012 | The result set is empty or the specified location is invalid. |
更多建议: