diff --git a/api/@ohos.data.distributedData.d.ts b/api/@ohos.data.distributedData.d.ts index e020a0403156886ce840b91c9e0a6fcb6cf666f1..9231cbc643dcd839ff67ccdbdc9a9f4e8ed299ec 100644 --- a/api/@ohos.data.distributedData.d.ts +++ b/api/@ohos.data.distributedData.d.ts @@ -14,51 +14,40 @@ */ import { AsyncCallback, Callback } from './basic'; -import { ValuesBucket } from './@ohos.data.ValuesBucket'; -import dataSharePredicates from './@ohos.data.dataSharePredicates'; -import DataShareResultSet from './@ohos.data.DataShareResultSet'; -import Context from './application/Context'; /** * Providers interfaces to creat a {@link KVManager} istances. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore */ - declare namespace distributedData { /** * Provides configuration information for {@link KVManager} instances, * including the caller's package name and distributed network type. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.KVManagerConfig */ interface KVManagerConfig { /** * Indicates the user information - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 */ userInfo: UserInfo; /** * Indicates the bundleName - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.KVManagerConfig#bundleName */ bundleName: string; - - /** - * Indicates the ability or hap context - * @since 9 - * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A - * @Note: if swap the area, you should close all the KV store and use the new Context to create the KVManager - */ - context: Context; } /** @@ -67,24 +56,24 @@ declare namespace distributedData { *
This class provides methods for obtaining the user ID and type, setting the user ID and type, * and checking whether two users are the same. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 */ interface UserInfo { /** * Indicates the user ID to set - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 */ userId?: string; /** * Indicates the user type to set - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 */ userType?: UserType; } @@ -92,72 +81,80 @@ declare namespace distributedData { /** * Enumerates user types. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 */ enum UserType { /** * Indicates a user that logs in to different devices using the same account. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 */ SAME_USER_ID = 0 } /** * KVStore constants - * @since 7 + * * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Constants */ namespace Constants { /** * max key length. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Constants#MAX_KEY_LENGTH */ const MAX_KEY_LENGTH = 1024; /** * max value length. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Constants#MAX_VALUE_LENGTH */ const MAX_VALUE_LENGTH = 4194303; /** * max device coordinate key length. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Constants#MAX_KEY_LENGTH_DEVICEs */ const MAX_KEY_LENGTH_DEVICE = 896; /** * max store id length. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Constants#MAX_STORE_ID_LENGTH */ const MAX_STORE_ID_LENGTH = 128; /** * max query length. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Constants#MAX_QUERY_LENGTH */ const MAX_QUERY_LENGTH = 512000; /** * max batch operation size. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Constants#MAX_BATCH_SIZE */ const MAX_BATCH_SIZE = 128; } @@ -167,56 +164,63 @@ declare namespace distributedData { * *
{@code ValueType} is obtained based on the value. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ValueType */ enum ValueType { /** * Indicates that the value type is string. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ValueType#STRING */ STRING = 0, /** * Indicates that the value type is int. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ValueType#INTEGER */ INTEGER = 1, /** * Indicates that the value type is float. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ValueType#FLOAT */ FLOAT = 2, /** * Indicates that the value type is byte array. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ValueTypeB#YTE_ARRAY * */ BYTE_ARRAY = 3, /** * Indicates that the value type is boolean. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ValueType#BOOLEAN * */ BOOLEAN = 4, /** * Indicates that the value type is double. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ValueType#DOUBLE */ DOUBLE = 5 } @@ -224,26 +228,29 @@ declare namespace distributedData { /** * Obtains {@code Value} objects stored in a {@link KVStore} database. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Value */ interface Value { /** * Indicates value type - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A * @see ValueType * @type {number} * @memberof Value + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Value#type */ type: ValueType; /** * Indicates value - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Value#value */ value: Uint8Array | string | number | boolean; } @@ -251,23 +258,26 @@ declare namespace distributedData { /** * Provides key-value pairs stored in the distributed database. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Entry */ interface Entry { /** * Indicates key - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Entry#key */ key: string; /** * Indicates value - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.Entry#value */ value: Value; } @@ -278,37 +288,42 @@ declare namespace distributedData { *
If you have subscribed to {@code KVStore}, you will receive data change notifications and obtain the changed data * from the parameters in callback methods upon data insertion, update, or deletion. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ChangeNotification */ interface ChangeNotification { /** * Indicates data addition records. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ChangeNotification#insertEntries */ insertEntries: Entry[]; /** * Indicates data update records. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ChangeNotification#updateEntries */ updateEntries: Entry[]; /** * Indicates data deletion records. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ChangeNotification#deleteEntries */ deleteEntries: Entry[]; /** * Indicates from device id. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.ChangeNotification#deviceId */ deviceId: string; } @@ -316,30 +331,34 @@ declare namespace distributedData { /** * Indicates the database synchronization mode. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SyncMode */ enum SyncMode { /** * Indicates that data is only pulled from the remote end. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SyncMode#PULL_ONLY */ PULL_ONLY = 0, /** * Indicates that data is only pushed from the local end. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SyncMode#PUSH_ONLY */ PUSH_ONLY = 1, /** * Indicates that data is pushed from the local end, and then pulled from the remote end. - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SyncMode#PUSH_PULL */ PUSH_PULL = 2 } @@ -347,32 +366,36 @@ declare namespace distributedData { /** * Describes the subscription type. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SubscribeType */ enum SubscribeType { /** * Subscription to local data changes - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SubscribeType#SUBSCRIBE_TYPE_LOCAL */ SUBSCRIBE_TYPE_LOCAL = 0, /** * Subscription to remote data changes - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SubscribeType#SUBSCRIBE_TYPE_REMOTE */ SUBSCRIBE_TYPE_REMOTE = 1, /** * Subscription to both local and remote data changes - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SubscribeType#SUBSCRIBE_TYPE_ALL */ SUBSCRIBE_TYPE_ALL = 2, } @@ -380,32 +403,35 @@ declare namespace distributedData { /** * Describes the {@code KVStore} type. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.KVStoreType */ enum KVStoreType { /** * Device-collaborated database, as specified by {@code DeviceKVStore} - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.KVStoreType#DEVICE_COLLABORATION */ DEVICE_COLLABORATION = 0, /** * Single-version database, as specified by {@code SingleKVStore} - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.KVStoreType#SINGLE_VERSION */ SINGLE_VERSION = 1, /** * Multi-version database, as specified by {@code MultiKVStore} - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore - * @import N/A + * @since 7 + * @deprecated since 9 */ MULTI_VERSION = 2, } @@ -413,17 +439,18 @@ declare namespace distributedData { /** * Describes the {@code KVStore} type. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SecurityLevel */ enum SecurityLevel { /** * NO_LEVEL: mains not set the security level. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore - * @import N/A + * @since 7 + * @deprecated since 9 */ NO_LEVEL = 0, @@ -431,9 +458,9 @@ declare namespace distributedData { * S0: mains the db is public. * There is no impact even if the data is leaked. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 */ S0 = 1, @@ -441,9 +468,10 @@ declare namespace distributedData { * S1: mains the db is low level security * There are some low impact, when the data is leaked. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SecurityLevel#S1 */ S1 = 2, @@ -451,9 +479,10 @@ declare namespace distributedData { * S2: mains the db is middle level security * There are some major impact, when the data is leaked. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SecurityLevel#S2 */ S2 = 3, @@ -461,9 +490,10 @@ declare namespace distributedData { * S3: mains the db is high level security * There are some severity impact, when the data is leaked. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SecurityLevel#S3 */ S3 = 5, @@ -471,9 +501,10 @@ declare namespace distributedData { * S4: mains the db is critical level security * There are some critical impact, when the data is leaked. * - * @since 7 * @syscap SystemCapability.DistributedDataManager.KVStore.Core - * @import N/A + * @since 7 + * @deprecated since 9 + * @useinstead ohos.data.distributedKVStore.SecurityLevel#S4 */ S4 = 6, } @@ -484,59 +515,67 @@ declare namespace distributedData { *
You can determine whether to create another database if a {@code KVStore} database is missing,
* whether to encrypt the database, and the database type.
*
- * @since 7
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Options
*/
interface Options {
/**
* Indicates whether to createa database when the database file does not exist
- * @since 7
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Options#createIfMissing
*/
createIfMissing?: boolean;
/**
* Indicates setting whether database files are encrypted
- * @since 7
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Options#encrypt
*/
encrypt?: boolean;
/**
* Indicates setting whether to back up database files
- * @since 7
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Options#backup
*/
backup?: boolean;
/**
* Indicates setting whether database files are automatically synchronized
- * @since 7
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
* @permission ohos.permission.DISTRIBUTED_DATASYNC
- * @import N/A
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Options#autoSync
*/
autoSync?: boolean;
/**
* Indicates setting the databse type
- * @since 7
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Options#kvStoreType
*/
kvStoreType?: KVStoreType;
/**
* Indicates setting the database security level
- * @since 7
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Options#securityLevel
*/
securityLevel?: SecurityLevel;
/**
* Indicates schema object
- * @since 8
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
- * @import N/A
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Options#schema
*/
schema?: Schema;
}
@@ -546,44 +585,55 @@ declare namespace distributedData {
*
* You can create Schema objects and put them in Options when creating or opening the database.
*
- * @since 8
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
- * @import N/A
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Schema
*/
class Schema {
/**
* A constructor used to create a Schema instance.
*
- * @since 8
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Schema#constructor
*/
constructor()
/**
* Indicates the root json object.
*
- * @since 8
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Schema#root
*/
root: FieldNode;
/**
* Indicates the string array of json.
*
- * @since 8
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Schema#indexes
*/
indexes: Array The leaf node must have a value; the non-leaf node must have a child {@code FieldNode}.
*
- * @since 8
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
- * @import N/A
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.FieldNode
*/
class FieldNode {
/**
* A constructor used to create a FieldNode instance with the specified field.
* name Indicates the field node name.
*
- * @since 8
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.FieldNode#constructor
*/
constructor(name: string)
/**
@@ -615,31 +668,39 @@ declare namespace distributedData {
*
* Adding a child node makes this node a non-leaf node. Field value will be ignored if it has child node.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
- * @param child The field node to append.
+ * @param child The field node to append.
* @returns Returns true if the child node is successfully added to this {@code FieldNode}; returns false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.FieldNode#appendChild
*/
appendChild(child: FieldNode): boolean;
/**
* Indicates the default value of fieldnode.
- *
- * @since 8
+ *
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.FieldNode#default
*/
default: string;
/**
* Indicates the nullable of database field.
- *
- * @since 8
+ *
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.FieldNode#nullable
*/
nullable: boolean;
/**
* Indicates the type of value.
- *
- * @since 8
+ *
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.FieldNode#type
*/
type: number;
}
@@ -650,434 +711,494 @@ declare namespace distributedData {
* The result set is created by using the {@code getResultSet} method in the {@code DeviceKVStore} class. This interface also provides
* methods for moving the data read position in the result set.
*
- * @since 7
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet
*/
interface KvStoreResultSet {
/**
* Obtains the number of lines in a result set.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
* @returns Returns the number of lines.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#getCount
*/
getCount(): number;
/**
* Obtains the current read position in a result set.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
* @returns Returns the current read position. The read position starts with 0.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#getPosition
*/
getPosition(): number;
/**
* Moves the read position to the first line.
*
* If the result set is empty, false is returned.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
* @returns Returns true if the operation succeeds; return false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#moveToFirst
*/
moveToFirst(): boolean;
/**
* Moves the read position to the last line.
*
* If the result set is empty, false is returned.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
* @returns Returns true if the operation succeeds; return false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#moveToLast
*/
moveToLast(): boolean;
/**
* Moves the read position to the next line.
*
* If the result set is empty or the data in the last line is being read, false is returned.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
* @returns Returns true if the operation succeeds; return false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#moveToNext
*/
moveToNext(): boolean;
/**
* Moves the read position to the previous line.
*
* If the result set is empty or the data in the first line is being read, false is returned.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
* @returns Returns true if the operation succeeds; return false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#moveToPrevious
*/
moveToPrevious(): boolean;
/**
* Moves the read position by a relative offset to the current position.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
* @param offset Indicates the relative offset to the current position. Anegative offset indicates moving backwards, and a
* positive offset indicates moving forewards. Forexample, if the current position is entry 1 and thisoffset is 2,
* the destination position will be entry 3; ifthe current position is entry 3 and this offset is -2,
* the destination position will be entry 1. The valid final position after moving forwards starts with 0. If the
* final position is invalid, false will be returned.
* @returns Returns true if the operation succeeds; return false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#move
*/
move(offset: number): boolean;
/**
* Moves the read position from 0 to an absolute position.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
* @param position Indicates the absolute position.
* @returns Returns true if the operation succeeds; return false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#moveToPosition
*/
moveToPosition(position: number): boolean;
/**
* Checks whether the read position is the first line.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
-
* @returns Returns true if the read position is the first line; returns false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#isFirst
*/
isFirst(): boolean;
/**
* Checks whether the read position is the last line.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
* @returns Returns true if the read position is the last line; returns false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#isLast
*/
isLast(): boolean;
/**
* Checks whether the read position is before the last line.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
* @returns Returns true if the read position is before the first line; returns false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#isBeforeFirst
*/
isBeforeFirst(): boolean;
/**
* Checks whether the read position is after the last line.
*
- * @since 8
+ * @returns Returns true if the read position is after the last line; returns false otherwise.
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @returns Returns true if the read position is after the last line; returns false otherwise.
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#isAfterLast
*/
isAfterLast(): boolean;
/**
* Obtains a key-value pair.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
* @returns Returns a key-value pair.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVStoreResultSet#getEntry
*/
getEntry(): Entry;
}
/**
* Represents a database query using a predicate.
- *
+ *
* This class provides a constructor used to create a {@code Query} instance, which is used to query data matching specified
* conditions in the database.
- *
+ *
* This class also provides methods for adding predicates to the {@code Query} instance.
- *
- * @since 8
+ *
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query
*/
class Query {
/**
* A constructor used to create a Query instance.
- *
- * @since 8
+ *
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#constructor
*/
- constructor()
+ constructor()
/**
* Resets this {@code Query} object.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @returns Returns the reset {@code Query} object.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#reset
*/
reset(): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is equal to the specified long value.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param value IIndicates the long value.
* @returns Returns the {@coed Query} object.
* @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#equalTo
*/
equalTo(field: string, value: number|string|boolean): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is not equal to the specified int value.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param value Indicates the int value.
* @returns Returns the {@coed Query} object.
* @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#notEqualTo
*/
notEqualTo(field: string, value: number|string|boolean): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is greater than or equal to the
* specified int value.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param value Indicates the int value.
* @returns Returns the {@coed Query} object.
* @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#greaterThan
*/
greaterThan(field: string, value: number|string|boolean): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is less than the specified int value.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param value Indicates the int value.
* @returns Returns the {@coed Query} object.
* @throws Throws this exception if input is invalid.
- */
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#lessThan
+ */
lessThan(field: string, value: number|string): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is greater than or equal to the
* specified int value.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param value Indicates the int value.
* @returns Returns the {@coed Query} object.
* @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#greaterThanOrEqualTo
*/
greaterThanOrEqualTo(field: string, value: number|string): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is less than or equal to the
* specified int value.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param value Indicates the int value.
- * @returns Returns the {@coed Query} object.
+ * @returns Returns the {@coed Query} object.
* @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#lessThanOrEqualTo
*/
lessThanOrEqualTo(field: string, value: number|string): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is null.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
- * @returns Returns the {@coed Query} object.
+ * @returns Returns the {@coed Query} object.
* @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#isNull
*/
isNull(field: string): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is within the specified int value list.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param valueList Indicates the int value list.
- * @returns Returns the {@coed Query} object.
+ * @returns Returns the {@coed Query} object.
* @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#inNumber
*/
inNumber(field: string, valueList: number[]): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is within the specified string value list.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
-
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param valueList Indicates the string value list.
- * @returns Returns the {@coed Query} object.
+ * @returns Returns the {@coed Query} object.
* @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#inString
*/
inString(field: string, valueList: string[]): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is not within the specified int value list.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param valueList Indicates the int value list.
* @returns Returns the {@coed Query} object.
- * @throws Throws this exception if input is invalid.
+ * @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#notInNumber
*/
notInNumber(field: string, valueList: number[]): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is not within the specified string value list.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param valueList Indicates the string value list.
- * @returns Returns the {@coed Query} object.
- * @throws Throws this exception if input is invalid.
+ * @returns Returns the {@coed Query} object.
+ * @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#notInString
*/
notInString(field: string, valueList: string[]): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is similar to the specified string value.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param value Indicates the string value.
- * @returns Returns the {@coed Query} object.
- * @throws Throws this exception if input is invalid.
+ * @returns Returns the {@coed Query} object.
+ * @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#like
*/
like(field: string, value: string): Query;
/**
* Constructs a {@code Query} object to query entries with the specified field whose value is not similar to the specified string value.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @param value Indicates the string value.
- * @returns Returns the {@coed Query} object.
- * @throws Throws this exception if input is invalid.
+ * @returns Returns the {@coed Query} object.
+ * @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#unlike
*/
unlike(field: string, value: string): Query;
/**
* Constructs a {@code Query} object with the and condition.
- *
+ *
* Multiple predicates should be connected using the and or or condition.
- *
- * @since 8
+ *
+ * @returns Returns the {@coed Query} object.
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
- * @returns Returns the {@coed Query} object.
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#and
*/
and(): Query;
/**
* Constructs a {@code Query} object with the or condition.
- *
+ *
* Multiple predicates should be connected using the and or or condition.
- *
- * @since 8
+ *
+ * @returns Returns the {@coed Query} object.
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
- * @returns Returns the {@coed Query} object.
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#or
*/
or(): Query;
/**
* Constructs a {@code Query} object to sort the query results in ascending order.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
- * @returns Returns the {@coed Query} object.
- * @throws Throws this exception if input is invalid.
+ * @returns Returns the {@coed Query} object.
+ * @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#orderByAsc
*/
orderByAsc(field: string): Query;
/**
* Constructs a {@code Query} object to sort the query results in descending order.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the field, which must start with $. and cannot contain ^.
* @returns Returns the {@coed Query} object.
- * @throws Throws this exception if input is invalid.
+ * @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#orderByDesc
*/
orderByDesc(field: string): Query;
/**
* Constructs a {@code Query} object to specify the number of results and the start position.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param total Indicates the number of results.
* @param offset Indicates the start position.
* @returns Returns the {@coed Query} object.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#limit
*/
limit(total: number, offset: number): Query;
/**
* Creates a {@code query} condition with a specified field that is not null.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param field Indicates the specified field.
* @returns Returns the {@coed Query} object.
- * @throws Throws this exception if input is invalid.
+ * @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#isNotNull
*/
isNotNull(field: string): Query;
/**
* Creates a query condition group with a left bracket.
- *
+ *
* Multiple query conditions in an {@code Query} object can be grouped. The query conditions in a group can be used as a
* whole to combine with other query conditions.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @returns Returns the {@coed Query} object.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#beginGroup
*/
beginGroup(): Query;
/**
* Creates a query condition group with a right bracket.
- *
+ *
* Multiple query conditions in an {@code Query} object can be grouped. The query conditions in a group can be used as a
* whole to combine with other query conditions.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @returns Returns the {@coed Query} object.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#endGroup
*/
endGroup(): Query;
/**
* Creates a query condition with a specified key prefix.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @param prefix Indicates the specified key prefix.
* @returns Returns the {@coed Query} object.
- * @throws Throws this exception if input is invalid.
+ * @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#prefixKey
*/
prefixKey(prefix: string): Query;
/**
* Sets a specified index that will be preferentially used for query.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
* @param index Indicates the index to set.
* @returns Returns the {@coed Query} object.
- * @throws Throws this exception if input is invalid.
+ * @throws Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#setSuggestIndex
*/
setSuggestIndex(index: string): Query;
/**
* Add device ID key prefix.Used by {@code DeviceKVStore}.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
* @param deviceId Specify device id to query from.
* @return Returns the {@code Query} object with device ID prefix added.
* @throw Throws this exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#deviceId
*/
deviceId(deviceId:string):Query;
/**
@@ -1085,11 +1206,12 @@ declare namespace distributedData {
*
* The String would be parsed to DB query format.
* The String length should be no longer than 500kb.
- *
- * @since 8
+ *
+ * @return String representing this {@code Query}.
* @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
- * @return String representing this {@code Query}.
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.Query#getSqlLike
*/
getSqlLike():string;
}
@@ -1102,227 +1224,182 @@ declare namespace distributedData {
* with input parameter {@code Options}. Distributed database types are defined in {@code KVStoreType},
* including {@code SingleKVStore}.
*
- * @since 7
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @import N/A
+ *
* @version 1
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.SingleKVStore
*/
interface KVStore {
/**
* Writes a key-value pair of the string type into the {@code KvStore} database.
*
* If you do not want to synchronize this key-value pair to other devices, set the write option in the local database.
- *
- * @since 7
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
* @param key Indicates the key. The length must be less than {@code MAX_KEY_LENGTH}.
* Spaces before and after the key will be cleared.
* @param value Indicates the string value, which must be less than 4 MB as a UTF-8 byte array.
- * @throws Throws this exception if any of the following errors
- * occurs: {@code SERVER_UNAVAILABLE}, {@code IPC_ERROR}, and
- * {@code DB_ERROR}.
+ * @throws Throws this exception if any of the following errors
+ * occurs: {@code SERVER_UNAVAILABLE}, {@code IPC_ERROR}, and {@code DB_ERROR}.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.SingleKVStore#put
*/
put(key: string, value: Uint8Array | string | number | boolean, callback: AsyncCallback After the database transaction is started, you can submit or roll back the operation.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
* @throws Throws this exception if a database error occurs.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.SingleKVStore#startTransaction
*/
startTransaction(callback: AsyncCallback The labels determine the devices with which data will be synchronized.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
* @param localLabels Indicates the synchronization labels of the local device.
* @param remoteSupportLabels Indicates the labels of the devices with which data will be synchronized.
* @throws Throws this exception if an internal service error occurs.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.SingleKVStore#setSyncRange
*/
setSyncRange(localLabels: string[], remoteSupportLabels: string[], callback: AsyncCallback Sync result is returned through asynchronous callback.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
* @param syncCallback Indicates the callback used to send the synchronization result to the caller.
* @throws Throws this exception if no {@code SingleKvStore} database is available.
- */
- on(event: 'syncComplete', syncCallback: Callback To create a {@code DeviceKVStore} database, you can use the {@link data.distributed.common.KVManager.getKvStore(Options, String)}
* method with {@code KvStoreType} set to {@code DEVICE_COLLABORATION} for the input parameter Options. This database manages distributed
* data by device, and cannot modify data synchronized from remote devices. When an application writes a key-value pair entry
* into the database, the system automatically adds the ID of the device running the application to the key.
- *
- * @since 8
+ *
* @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
- * @import N/A
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.DeviceKVStore
*/
interface DeviceKVStore extends KVStore {
/**
* Obtains the {@code String} value matching a specified device ID and key.
*
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
* @param deviceId Indicates the device to be queried.
* @param key Indicates the key of the value to be queried.
* @return Returns the value matching the given criteria.
* @throws Throws this exception if any of the following errors occurs: {@code INVALID_ARGUMENT},
* {@code SERVER_UNAVAILABLE}, {@code IPC_ERROR}, {@code DB_ERROR}, and {@code KEY_NOT_FOUND}.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.DeviceKVStore#get
*/
get(deviceId: string, key: string, callback: AsyncCallback The {@code KvStoreResultSet} object can be used to query all key-value pairs that meet the search criteria. Each {@code KvStore}
* instance can have a maximum of four {@code KvStoreResultSet} objects at the same time. If you have created four objects,
* calling this method will return a failure. Therefore, you are advised to call the closeResultSet method to close unnecessary
* {@code KvStoreResultSet} objects in a timely manner.
- *
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ *
* @param deviceId Identifies the device whose data is to be queried.
* @param keyPrefix Indicates the key prefix to match.
* @returns Returns the {@code KvStoreResultSet} objects.
* @throws Throws this exception if any of the following errors occurs: {@code INVALID_ARGUMENT},
* {@code SERVER_UNAVAILABLE}, {@code IPC_ERROR}, {@code DB_ERROR}.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.DeviceKVStore#getResultSet
*/
getResultSet(deviceId: string, keyPrefix: string, callback: AsyncCallback This method returns immediately and sync result will be returned through asynchronous callback.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
- * @param deviceIds Indicates the list of IDs of devices whose
- * @param delayMs Indicates the delay allowed for the synchronization, in milliseconds.
- * {@code DeviceKVStore} databases are to be synchronized.
- * @param mode Indicates the synchronization mode, {@code PUSH}, {@code PULL}, or
- * {@code PUSH_PULL}.
- * @permission ohos.permission.DISTRIBUTED_DATASYNC
- * @throws Throws this exception if no DeviceKVStore database is available.
- */
- sync(deviceIds: string[], mode: SyncMode, delayMs?: number): void;
/**
* Synchronizes {@code DeviceKVStore} databases.
*
* This method returns immediately and sync result will be returned through asynchronous callback.
- * @since 9
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
+ * @permission ohos.permission.DISTRIBUTED_DATASYNC
* @param deviceIds Indicates the list of IDs of devices whose
* @param delayMs Indicates the delay allowed for the synchronization, in milliseconds.
* {@code DeviceKVStore} databases are to be synchronized.
- * @param query Indicates the {@code Query} object.
* @param mode Indicates the synchronization mode, {@code PUSH}, {@code PULL}, or
* {@code PUSH_PULL}.
- * @permission ohos.permission.DISTRIBUTED_DATASYNC
* @throws Throws this exception if no DeviceKVStore database is available.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.DeviceKVStore#sync
*/
- sync(deviceIds: string[], query: Query, mode: SyncMode, delayMs?: number): void;
+ sync(deviceIds: string[], mode: SyncMode, delayMs?: number): void;
/**
* Register Synchronizes DeviceKVStore databases callback.
- *
+ *
* Sync result is returned through asynchronous callback.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
* @param syncCallback Indicates the callback used to send the synchronization result to the caller.
* @throws Throws this exception if no DeviceKVStore database is available.
- */
- on(event: 'syncComplete', syncCallback: Callback You must pass {@link KVManagerConfig} to provide configuration information
* for creating the {@link KVManager} instance.
*
- * @since 7
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
* @param config Indicates the {@link KVStore} configuration information,
* including the user information and package name.
* @return Returns the {@code KVManager} instance.
* @throws Throws exception if input is invalid.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 7
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore#createKVManager
*/
function createKVManager(config: KVManagerConfig, callback: AsyncCallback You can use this method to delete a {@code KvStore} database not in use. After the database is deleted, all its data will be
* lost.
- * @since 8
- * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ *
* @param storeId Identifies the {@code KvStore} database to delete.
* @throws Throws this exception if any of the following errors
* occurs: {@code INVALID_ARGUMENT},
* {@code SERVER_UNAVAILABLE}, {@code STORE_NOT_FOUND},
* {@code DB_ERROR}, {@code PERMISSION_DENIED}, and {@code IPC_ERROR}.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 8
+ * @deprecated since 9
+ * @useinstead ohos.data.distributedKVStore.KVManager#deleteKVStore
*/
deleteKVStore(appId: string, storeId: string, callback: AsyncCallback {@code ValueType} is obtained based on the value.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ enum ValueType {
+ /**
+ * Indicates that the value type is string.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ STRING,
+
+ /**
+ * Indicates that the value type is int.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ INTEGER,
+
+ /**
+ * Indicates that the value type is float.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ FLOAT,
+
+ /**
+ * Indicates that the value type is byte array.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ * */
+ BYTE_ARRAY,
+
+ /**
+ * Indicates that the value type is boolean.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ * */
+ BOOLEAN,
+
+ /**
+ * Indicates that the value type is double.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ DOUBLE,
+ }
+
+ /**
+ * Obtains {@code Value} objects stored in a {@link SingleKVStore} or {@link DeviceKVStore} database.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ interface Value {
+ /**
+ * Indicates the value type
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @see ValueType
+ * @since 9
+ */
+ type: ValueType;
+ /**
+ * Indicates the value
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ value: Uint8Array | string | number | boolean;
+ }
+
+ /**
+ * Provides key-value pairs stored in the distributedKVStore.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ interface Entry {
+ /**
+ * Indicates the key
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ key: string;
+ /**
+ * Indicates the value
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ value: Value;
+ }
+
+ /**
+ * Receive notifications of all data changes, including data insertion, update, and deletion.
+ *
+ * If you have subscribed to {@code SingleKVStore} or {@code DeviceKVStore}, you will receive
+ * data change notifications and obtain the changed data from the parameters in callback methods
+ * upon data insertion, update or deletion.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ interface ChangeNotification {
+ /**
+ * Indicates data insertion records.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ insertEntries: Entry[];
+ /**
+ * Indicates data update records.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ updateEntries: Entry[];
+ /**
+ * Indicates data deletion records.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ deleteEntries: Entry[];
+ /**
+ * Indicates the device id which brings the data change.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ deviceId: string;
+ }
+
+ /**
+ * Indicates the database synchronization mode.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ enum SyncMode {
+ /**
+ * Indicates that data is only pulled from the remote end.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ PULL_ONLY,
+ /**
+ * Indicates that data is only pushed from the local end.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ PUSH_ONLY,
+ /**
+ * Indicates that data is pushed from the local end, and then pulled from the remote end.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ PUSH_PULL,
+ }
+
+ /**
+ * Describes the subscription type.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ enum SubscribeType {
+ /**
+ * Subscription to local data changes
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ SUBSCRIBE_TYPE_LOCAL,
+
+ /**
+ * Subscription to remote data changes
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ SUBSCRIBE_TYPE_REMOTE,
+
+ /**
+ * Subscription to both local and remote data changes
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ SUBSCRIBE_TYPE_ALL,
+ }
+
+ /**
+ * Describes the KVStore type.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ enum KVStoreType {
+ /**
+ * Device-collaborated database, as specified by {@code DeviceKVStore}
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ DEVICE_COLLABORATION,
+
+ /**
+ * Single-version database, as specified by {@code SingleKVStore}
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ SINGLE_VERSION,
+ }
+
+ /**
+ * Describes the KVStore security level.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ enum SecurityLevel {
+ /**
+ * S1: means the db is in the low security level
+ * There are some low impact when the data is leaked.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ S1,
+
+ /**
+ * S2: means the db is in the middle security level
+ * There are some major impact when the data is leaked.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ S2,
+
+ /**
+ * S3: means the db is in the high security level
+ * There are some severity impact when the data is leaked.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ S3,
+
+ /**
+ * S4: means the db is in the critical security level
+ * There are some critical impact when the data is leaked.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ S4,
+ }
+
+ /**
+ * Provides configuration options to create a {@code SingleKVStore} or {@code DeviceKVStore}.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ interface Options {
+ /**
+ * Indicates whether to create a database when the database file does not exist
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ createIfMissing?: boolean;
+ /**
+ * Indicates whether database files to be encrypted
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ encrypt?: boolean;
+ /**
+ * Indicates whether to back up database files
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ backup?: boolean;
+ /**
+ * Indicates whether database files are automatically synchronized
+ * @permission ohos.permission.DISTRIBUTED_DATASYNC
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ autoSync?: boolean;
+ /**
+ * Indicates the database type
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ kvStoreType?: KVStoreType;
+ /**
+ * Indicates the database security level
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ securityLevel: SecurityLevel;
+ /**
+ * Indicates the database schema
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ schema?: Schema;
+ }
+
+ /**
+ * Represents the database schema.
+ *
+ * You can set the schema object in options when create or open the database.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ class Schema {
+ /**
+ * A constructor used to create a Schema instance.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ constructor()
+ /**
+ * Indicates the root json object.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ root: FieldNode;
+ /**
+ * Indicates the string array of json.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ indexes: Array With a {@link Schema} instance, you can define the value fields which stored in the database.
+ *
+ * A FieldNode of the {@link Schema} instance is either a leaf or a non-leaf node.
+ *
+ * The leaf node must have a value; the non-leaf node must have a child {@code FieldNode}.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ class FieldNode {
+ /**
+ * A constructor used to create a FieldNode instance with the specified field.
+ * name Indicates the field node name.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ constructor(name: string)
+ /**
+ * Adds a child node to this {@code FieldNode}.
+ *
+ * Add a child node to makes this node a non-leaf node and field value will be ignored if it has a child node.
+ *
+ * @param {FieldNode} child - The field node to append.
+ * @returns Returns true if the child node is successfully added to this {@code FieldNode} and false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ appendChild(child: FieldNode): boolean;
+ /**
+ * Indicates the default value of field node.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ default: string;
+ /**
+ * Indicates the nullable of database field.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ nullable: boolean;
+ /**
+ * Indicates the type of value.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ type: number;
+ }
+
+ /**
+ * Provides methods to operate the result set of the {@code SingleKVStore} or {@code DeviceKVStore} database.
+ *
+ * The result set is created by using the {@code getResultSet} method in the {@code SingleKVStore} or
+ * {@code DeviceKVStore} class. This interface also provides methods to move the data read
+ * position in the result set.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ interface KVStoreResultSet {
+ /**
+ * Obtains the number of lines in a result set.
+ *
+ * @returns Returns the number of lines.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ getCount(): number;
+ /**
+ * Obtains the current read position in a result set.
+ *
+ * @returns Returns the current read position. The read position starts with 0.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ getPosition(): number;
+ /**
+ * Moves the read position to the first line.
+ *
+ * If the result set is empty, false is returned.
+ *
+ * @returns Returns true if the operation succeeds; return false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ moveToFirst(): boolean;
+ /**
+ * Moves the read position to the last line.
+ *
+ * If the result set is empty, false is returned.
+ *
+ * @returns Returns true if the operation succeeds; return false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ moveToLast(): boolean;
+ /**
+ * Moves the read position to the next line.
+ *
+ * If the result set is empty or the data in the last line is being read, false is returned.
+ *
+ * @returns Returns true if the operation succeeds; return false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ moveToNext(): boolean;
+ /**
+ * Moves the read position to the previous line.
+ *
+ * If the result set is empty or the data in the first line is being read, false is returned.
+ *
+ * @returns Returns true if the operation succeeds; return false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ moveToPrevious(): boolean;
+ /**
+ * Moves the read position by a relative offset to the current position.
+ *
+ * @param {number} offset - Indicates the relative offset to the current position. Anegative offset indicates moving
+ * backwards, and a positive offset indicates moving forewards. Forexample, if the current position is entry 1 and
+ * thisoffset is 2, the destination position will be entry 3; ifthe current position is entry 3 and this offset is -2,
+ * the destination position will be entry 1. The valid final position after moving forwards starts with 0. If the
+ * final position is invalid, false will be returned.
+ * @returns Returns true if the operation succeeds; return false otherwise.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ move(offset: number): boolean;
+ /**
+ * Moves the read position from 0 to an absolute position.
+ *
+ * @param {number} position - Indicates the absolute position.
+ * @returns Returns true if the operation succeeds; return false otherwise.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ moveToPosition(position: number): boolean;
+ /**
+ * Checks whether the read position is the first line.
+ *
+ * @returns Returns true if the read position is the first line; returns false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ isFirst(): boolean;
+ /**
+ * Checks whether the read position is the last line.
+ *
+ * @returns Returns true if the read position is the last line; returns false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ isLast(): boolean;
+ /**
+ * Checks whether the read position is before the last line.
+ *
+ * @returns Returns true if the read position is before the first line; returns false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ isBeforeFirst(): boolean;
+ /**
+ * Checks whether the read position is after the last line.
+ *
+ * @returns Returns true if the read position is after the last line; returns false otherwise.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ isAfterLast(): boolean;
+ /**
+ * Obtains a key-value pair.
+ *
+ * @returns Returns a key-value pair.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ getEntry(): Entry;
+ }
+
+ /**
+ * Represents a database query using predicates.
+ *
+ * This class provides a constructor used to create a {@code Query} instance, which is used to query data
+ * matching specified conditions in the database.
+ *
+ * This class also provides methods to add predicates to the {@code Query} instance.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ class Query {
+ /**
+ * A constructor used to create a Query instance.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ constructor()
+ /**
+ * Resets this {@code Query} object.
+ *
+ * @returns Returns the reset {@code Query} object.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ reset(): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is equal to the specified long value.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {number|string|boolean} value - Indicates the value to be compared.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ equalTo(field: string, value: number | string | boolean): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is not equal to the specified int value.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {number|string|boolean} value - Indicates the value to be compared.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ notEqualTo(field: string, value: number | string | boolean): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is greater than or equal to the
+ * specified int value.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {number|string|boolean} value - Indicates the value to be compared.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ greaterThan(field: string, value: number | string | boolean): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is less than the specified int value.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {number|string} value - Indicates the value to be compared.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ lessThan(field: string, value: number | string): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is greater than or
+ * equal to the specified int value.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {number|string} value - Indicates the value to be compared.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ greaterThanOrEqualTo(field: string, value: number | string): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is less than or equal to the
+ * specified int value.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {number|string} value - Indicates the value to be compared.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ lessThanOrEqualTo(field: string, value: number | string): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is null.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ isNull(field: string): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is within the specified int value list.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {number[]} valueList - Indicates the int value list.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ inNumber(field: string, valueList: number[]): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is within the specified string value list.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {string[]} valueList - Indicates the string value list.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ inString(field: string, valueList: string[]): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is not within the specified int value list.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {number[]} valueList - Indicates the int value list.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ notInNumber(field: string, valueList: number[]): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is not within the specified string value list.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {string[]} valueList - Indicates the string value list.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ notInString(field: string, valueList: string[]): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is similar to the specified string value.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {string} value - Indicates the string value.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ like(field: string, value: string): Query;
+ /**
+ * Constructs a {@code Query} object to query entries with the specified field whose value is not similar to the specified string value.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @param {string} value - Indicates the string value.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ unlike(field: string, value: string): Query;
+ /**
+ * Constructs a {@code Query} object with the and condition.
+ *
+ * Multiple predicates should be connected using the and or or condition.
+ *
+ * @returns Returns the {@coed Query} object.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ and(): Query;
+ /**
+ * Constructs a {@code Query} object with the or condition.
+ *
+ * Multiple predicates should be connected using the and or or condition.
+ *
+ * @returns Returns the {@coed Query} object.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ or(): Query;
+ /**
+ * Constructs a {@code Query} object to sort the query results in ascending order.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ orderByAsc(field: string): Query;
+ /**
+ * Constructs a {@code Query} object to sort the query results in descending order.
+ *
+ * @param {string} field - Indicates the field, which must start with $. and cannot contain ^.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ orderByDesc(field: string): Query;
+ /**
+ * Constructs a {@code Query} object to specify the number of results and the start position.
+ *
+ * @param {number} total - Indicates the number of results.
+ * @param {number} offset - Indicates the start position.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ limit(total: number, offset: number): Query;
+ /**
+ * Creates a {@code Query} condition with a specified field that is not null.
+ *
+ * @param {string} field - Indicates the specified field.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ isNotNull(field: string): Query;
+ /**
+ * Creates a query condition group with a left bracket.
+ *
+ * Multiple query conditions in an {@code Query} object can be grouped. The query conditions in a group can be used as a
+ * whole to combine with other query conditions.
+ *
+ * @returns Returns the {@coed Query} object.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ beginGroup(): Query;
+ /**
+ * Creates a query condition group with a right bracket.
+ *
+ * Multiple query conditions in an {@code Query} object can be grouped. The query conditions in a group can be used as a
+ * whole to combine with other query conditions.
+ *
+ * @returns Returns the {@coed Query} object.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ endGroup(): Query;
+ /**
+ * Creates a query condition with a specified key prefix.
+ *
+ * @param {string} prefix - Indicates the specified key prefix.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ prefixKey(prefix: string): Query;
+ /**
+ * Sets a specified index that will be preferentially used for query.
+ *
+ * @param {string} index - Indicates the index to set.
+ * @returns Returns the {@coed Query} object.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ setSuggestIndex(index: string): Query;
+ /**
+ * Add device ID key prefix.Used by {@code DeviceKVStore}.
+ *
+ * @param {string} deviceId - Specify device id to query from.
+ * @return Returns the {@code Query} object with device ID prefix added.
+ * @throws {BusinessError} 401 - if parameter check failed.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ deviceId(deviceId:string):Query;
+ /**
+ * Get a String that repreaents this {@code Query}.
+ *
+ * The String would be parsed to DB query format.
+ * The String length should be no longer than 500kb.
+ *
+ * @return String representing this {@code Query}.
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ getSqlLike():string;
+ }
+
+ /**
+ * Provides methods related to single-version distributed databases.
+ *
+ * To create a {@code SingleKVStore} database,
+ * you can use the {@link data.distributed.common.KVManager#getKVStore​(Options, String)} method
+ * with {@code KVStoreType} set to {@code SINGLE_VERSION} for the input parameter {@code Options}.
+ * This database synchronizes data to other databases in time sequence.
+ * The {@code SingleKVStore} database does not support
+ * synchronous transactions, or data search using snapshots.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.Core
+ * @since 9
+ */
+ interface SingleKVStore {
+ /**
+ * Writes a key-value pair of the string type into the {@code SingleKVStore} database.
+ *
+ * If you do not want to synchronize this key-value pair to other devices, set the write option in the local database.
+ *
+ * @param {string} key - Indicates the key. Length must be less than {@code MAX_KEY_LENGTH}.
+ * Spaces before and after the key will be cleared.
+ * @param {Uint8Array|string|number|boolean} value - Indicates the value to be inserted.
+ * @param {AsyncCallback If you do not want to synchronize this key-value pair to other devices, set the write option in the local database.
+ *
+ * @param {string} key - Indicates the key. Length must be less than {@code MAX_KEY_LENGTH}.
+ * Spaces before and after the key will be cleared.
+ * @param {Uint8Array|string|number|boolean} value - Indicates the value to be inserted.
+ * @returns {Promise After the database transaction is started, you can submit or roll back the operation.
+ *
+ * @param {AsyncCallback After the database transaction is started, you can submit or roll back the operation.
+ *
+ * @returns {Promise The labels determine the devices with which data will be synchronized.
+ *
+ * @param {string[]} localLabels - Indicates the synchronization labels of the local device.
+ * @param {string[]} remoteSupportLabels - Indicates the labels of the devices with which
+ * data will be synchronized.
+ * @param {AsyncCallback The labels determine the devices with which data will be synchronized.
+ *
+ * @param {string[]} localLabels - Indicates the synchronization labels of the local device.
+ * @param {string[]} remoteSupportLabels - Indicates the labels of the devices with which
+ * data will be synchronized.
+ * @returns {Promise Sync result is returned through asynchronous callback.
+ *
+ * @param {Callback To create a {@code DeviceKVStore} database, you can use the {@link data.distributed.common.KVManager.getKVStore(Options, String)}
+ * method with {@code KVStoreType} set to {@code DEVICE_COLLABORATION} for the input parameter Options. This database manages distributed
+ * data by device, and cannot modify data synchronized from remote devices. When an application writes a key-value pair entry
+ * into the database, the system automatically adds the ID of the device running the application to the key.
+ *
+ * @syscap SystemCapability.DistributedDataManager.KVStore.DistributedKVStore
+ * @since 9
+ */
+ interface DeviceKVStore extends SingleKVStore {
+ /**
+ * Obtains the {@code String} value matching a specified device ID and key.
+ *
+ * @param {string} deviceId - Indicates the device to be queried.
+ * @param {string} key - Indicates the key of the value to be queried.
+ * @param {AsyncCallback