@ohos.data.dataSharePredicates (数据共享谓词)(系统接口)

谓词(DataSharePredicates) 是开发者通过DataShare查询数据库中的数据所使用的筛选条件,经常被应用在更新数据(update)、删除数据(delete)和查询数据(query)中。

谓词的接口函数与数据库的筛选条件一一对应,开发者在使用前需了解数据库相关知识。

谓词(DataSharePredicates)的使用场景如下:

  • 用于调用关系型数据库键值型数据库系统接口时的检索条件使用。此种场景下,开发者根据使用的数据库类型参考对应的谓词使用方法。

说明:

  • 本模块首批接口从API version 9开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

  • 本模块接口仅可在Stage模型下使用。

  • 当前页面仅包含本模块的系统接口,其他公开接口参见@ohos.data.dataSharePredicates (数据共享谓词)

导入模块

import { dataSharePredicates } from '@kit.ArkData';

DataSharePredicates

提供用于不同实现不同查询方法的数据共享谓词。该类型不是多线程安全的,如果应用中存在多线程同时操作该类派生出的实例,注意加锁保护。

contains

contains(field: string, value: string): DataSharePredicates

该接口用于配置谓词以匹配值包含指定字段的字段。

目前仅关系型数据库支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
field string 数据库表中的列名。
value string 指示值中包含该字段。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.contains("NAME", "os");

beginsWith

beginsWith(field: string, value: string): DataSharePredicates

该接口用于配置谓词以匹配值以指定字符串起始的字段。

目前仅关系型数据库支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
field string 数据库表中的列名。
value string 指示值以该字符串起始。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.beginsWith("NAME", "os");

endsWith

endsWith(field: string, value: string): DataSharePredicates

该接口用于配置谓词以匹配值以指定字符串结尾的字段。

目前仅关系型数据库支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
field string 数据库表中的列名。
value string 指示值以该字符串结尾。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.endsWith("NAME", "os");

isNull

isNull(field: string): DataSharePredicates

该接口用于配置谓词以匹配值为null的字段。

目前仅关系型数据库及键值型数据库支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
field string 数据库表中的列名。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.isNull("NAME");

isNotNull

isNotNull(field: string): DataSharePredicates

该接口用于配置谓词以匹配值不为null的字段。

目前仅关系型数据库及键值型数据库支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
field string 数据库表中的列名。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.isNotNull("NAME");

unlike

unlike(field: string, value: string): DataSharePredicates

该接口用于配置谓词以匹配不类似指定通配符表达式的字段。

目前仅关系型数据库及键值型数据库支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
field string 数据库表中的列名。
value string 指示要与谓词匹配的通配符表达式。
表达式中'%'代表零个、一个或多个数字或字符,'_'代表一个单一的数字或字符,不区分大小写。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.unlike("NAME", "%os%");

glob

glob(field: string, value: string): DataSharePredicates

该接口用于配置谓词以匹配指定通配符表达式的字段。

目前仅关系型数据库支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
field string 数据库表中的列名。
value string 指示要与谓词匹配的通配符表达式。
表达式中'*'代表零个、一个或多个数字或字符,'?'代表一个单一的数字或字符,区分大小写。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.glob("NAME", "?h*g");

distinct

distinct(): DataSharePredicates

该接口用于配置谓词以过滤重复记录并仅保留其中一个。

目前仅关系型数据库支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.equalTo("NAME", "Rose").distinct();

groupBy

groupBy(fields: Array<string>): DataSharePredicates

该接口用于配置谓词按指定列分组查询结果。

目前仅关系型数据库支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
fields Array<string> 指定分组依赖的列名。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.groupBy(["AGE", "NAME"]);

indexedBy

indexedBy(field: string): DataSharePredicates

该接口用于配置谓词按指定索引列查询结果。使用该方法前,需要设置索引列。

目前仅关系型数据库支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
field string 索引列的名称。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.indexedBy("SALARY_INDEX");

prefixKey

prefixKey(prefix: string): DataSharePredicates

该接口用于配置谓词以匹配键前缀的指定字段。

目前仅KVDB支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
prefix string 指定的键前缀。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.prefixKey("NAME");

inKeys

inKeys(keys: Array<string>): DataSharePredicates

该接口用于配置谓词以匹配键在指定范围内的字段。

目前仅KVDB支持该谓词。

系统接口: 此接口为系统接口。

系统能力: SystemCapability.DistributedDataManager.DataShare.Core

参数:

参数名 类型 必填 说明
keys Array<string> 指定范围的键数组。

返回值:

类型 说明
DataSharePredicates 返回与指定字段匹配的谓词。

示例:

let predicates = new dataSharePredicates.DataSharePredicates();
predicates.inKeys(["Lisa", "Rose"]);