js-apis-application-dataShareExtensionAbility.md 12.3 KB
Newer Older
Z
zengyawen 已提交
1
# @ohos.application.DataShareExtensionAbility (数据共享扩展能力)
S
songruirui 已提交
2

S
songruirui 已提交
3
**DataShareExtensionAbility**基于ExtensionAbility框架,提供支持数据共享业务的能力。
S
songruirui 已提交
4 5

>**说明:** 
S
songruirui 已提交
6
>
7
> 本模块首批接口从API version 9开始支持,后续版本的新增接口,采用上角标单独标记接口的起始版本。
S
songruirui 已提交
8
>
9
> 本模块接口为系统接口。
S
songruirui 已提交
10
>
11
> 本模块接口仅可在Stage模型下使用。
S
songruirui 已提交
12 13 14 15


## 导入模块

S
songruirui 已提交
16
```ts
M
mingxihua 已提交
17
import DataShareExtensionAbility from '@ohos.application.DataShareExtensionAbility';
S
songruirui 已提交
18 19
```

D
duanweiling 已提交
20 21 22 23
## 属性

**系统能力**:SystemCapability.DistributedDataManager.DataShare.Provider

24
| 名称 | 类型 | 可读 | 可写 | 说明 | 
D
duanweiling 已提交
25
| -------- | -------- | -------- | -------- | -------- |
S
srr101 已提交
26
| context<sup>10+</sup> | [ExtensionContext](js-apis-inner-application-extensionContext.md)  | 是 | 否 |表示数据共享扩展能力上下文。继承自[ExtensionContext] |
D
duanweiling 已提交
27

S
songruirui 已提交
28 29
## onCreate

S
songruirui 已提交
30
onCreate?(want: Want, callback: AsyncCallback&lt;void&gt;): void
S
songruirui 已提交
31

S
songruirui 已提交
32
DataShare客户端连接DataShareExtensionAbility服务端时,服务端回调此接口,执行初始化业务逻辑操作。该方法可以选择性重写。
S
songruirui 已提交
33

S
songruirui 已提交
34
**系统能力:**  SystemCapability.DistributedDataManager.DataShare.Provider
S
songruirui 已提交
35 36 37

**参数:**

38
| 参数名 | 类型 | 必填 | 说明 |
S
songruirui 已提交
39
| ----- | ------ | ------ | ------ |
40
| want | [Want](js-apis-application-want.md#want) | 是  | Want类型信息,包括Ability名称、Bundle名称等。 |
S
修改  
songruirui 已提交
41
| callback | AsyncCallback&lt;void&gt; | 是 | 回调函数。无返回值。 |
S
songruirui 已提交
42 43 44

**示例:**

S
songruirui 已提交
45
```ts
N
niudongyao 已提交
46
import rdb from '@ohos.data.relationalStore';
S
songruirui 已提交
47

M
mingxihua 已提交
48 49 50
let DB_NAME = 'DB00.db';
let TBL_NAME = 'TBL00';
let DDL_TBL_CREATE = 'CREATE TABLE IF NOT EXISTS '
51
    + TBL_NAME
M
mingxihua 已提交
52
    + ' (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, phoneNumber DOUBLE, isStudent BOOLEAN, Binary BINARY)';
S
修改  
songruirui 已提交
53
let rdbStore;
S
songruirui 已提交
54

W
wanning.fang 已提交
55
export default class DataShareExtAbility extends DataShareExtensionAbility {
D
duanweiling 已提交
56
    onCreate(want, callback) {
W
wanning.fang 已提交
57
        rdb.getRdbStore(this.context, {
N
niudongyao 已提交
58 59
            name: DB_NAME,
            securityLevel: rdb.SecurityLevel.S1
N
niudongyao 已提交
60
        }, function (err, data) {
S
srr101 已提交
61
            console.info(`getRdbStore done, data : ${data}`);
W
wanning.fang 已提交
62 63
            rdbStore = data;
            rdbStore.executeSql(DDL_TBL_CREATE, [], function (err) {
S
srr101 已提交
64
                console.error(`executeSql done, error message : ${err}`);
W
wanning.fang 已提交
65 66 67 68
            });
            if (callback) {
                callback();
            }
S
songruirui 已提交
69
        });
W
wanning.fang 已提交
70 71
    }
};
S
songruirui 已提交
72 73 74 75
```

## insert

S
songruirui 已提交
76
insert?(uri: string, valueBucket: ValuesBucket, callback: AsyncCallback&lt;number&gt;): void
S
songruirui 已提交
77

S
songruirui 已提交
78
在数据库插入时回调此接口,该方法可以选择性重写。
S
songruirui 已提交
79

S
修改  
songruirui 已提交
80
**系统能力:**  SystemCapability.DistributedDataManager.DataShare.Provider
S
songruirui 已提交
81 82 83

**参数:**

84
| 参数名 | 类型 | 必填 | 说明 |
S
songruirui 已提交
85
| ----- | ------ | ------ | ------ |
S
songruirui 已提交
86
| uri |string | 是  | 指示要插入的数据的路径。 |
M
m00512953 已提交
87
| valueBucket |[ValuesBucket](js-apis-data-valuesBucket.md#valuesbucket) | 是 | 指示要插入的数据。 |
S
修改  
songruirui 已提交
88
| callback |AsyncCallback&lt;number&gt; | 是 | 回调函数。返回插入数据记录的索引。 |
S
songruirui 已提交
89 90 91

**示例:**

S
songruirui 已提交
92
```ts
N
niudongyao 已提交
93
import rdb from '@ohos.data.relationalStore';
94

M
mingxihua 已提交
95 96 97
let DB_NAME = 'DB00.db';
let TBL_NAME = 'TBL00';
let DDL_TBL_CREATE = 'CREATE TABLE IF NOT EXISTS '
98
    + TBL_NAME
M
mingxihua 已提交
99
    + ' (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, phoneNumber DOUBLE, isStudent BOOLEAN, Binary BINARY)';
100 101
let rdbStore;

W
wanning.fang 已提交
102
export default class DataShareExtAbility extends DataShareExtensionAbility {
D
duanweiling 已提交
103
    insert(uri, valueBucket, callback) {
M
mingxihua 已提交
104
        if (valueBucket === null) {
S
srr101 已提交
105
            console.error('invalid valueBuckets');
W
wanning.fang 已提交
106
            return;
S
songruirui 已提交
107
        }
108
        rdbStore.insert(TBL_NAME, valueBucket, function (err, ret) {
S
srr101 已提交
109
            console.info(`callback ret: ${ret}`);
M
mingxihua 已提交
110
            if (callback !== undefined) {
W
wanning.fang 已提交
111 112 113 114 115
                callback(err, ret);
            }
        });
    }
};
S
songruirui 已提交
116 117
```

S
songruirui 已提交
118
## update
S
songruirui 已提交
119

S
songruirui 已提交
120
update?(uri: string, predicates: dataSharePredicates.DataSharePredicates, valueBucket: ValuesBucket, callback: AsyncCallback&lt;number&gt;): void
S
songruirui 已提交
121

S
songruirui 已提交
122
在数据库更新时服务端回调此接口,该方法可以选择性重写。
S
songruirui 已提交
123

S
修改  
songruirui 已提交
124
**系统能力:**  SystemCapability.DistributedDataManager.DataShare.Provider
S
songruirui 已提交
125

S
songruirui 已提交
126
**参数:**
S
songruirui 已提交
127

128
| 参数名 | 类型 | 必填 | 说明 |
S
songruirui 已提交
129 130
| ----- | ------ | ------ | ------ |
| uri | string | 是  | 指示要更新的数据的路径。 |
131
| predicates | [dataSharePredicates.DataSharePredicates](js-apis-data-dataSharePredicates.md#datasharepredicates) | 是  | 指示筛选条件。 |
M
m00512953 已提交
132
| valueBucket | [ValuesBucket](js-apis-data-valuesBucket.md#valuesbucket) | 是 | 指示要更新的数据。 |
S
修改  
songruirui 已提交
133
| callback | AsyncCallback&lt;number&gt; | 是 | 回调函数。返回更新的数据记录数。 |
S
songruirui 已提交
134 135 136

**示例:**

S
songruirui 已提交
137
```ts
N
niudongyao 已提交
138
import rdb from '@ohos.data.relationalStore';
139

M
mingxihua 已提交
140 141 142
let DB_NAME = 'DB00.db';
let TBL_NAME = 'TBL00';
let DDL_TBL_CREATE = 'CREATE TABLE IF NOT EXISTS '
143
    + TBL_NAME
M
mingxihua 已提交
144
    + ' (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, phoneNumber DOUBLE, isStudent BOOLEAN, Binary BINARY)';
145 146
let rdbStore;

W
wanning.fang 已提交
147
export default class DataShareExtAbility extends DataShareExtensionAbility {
D
duanweiling 已提交
148
    update(uri, predicates, valueBucket, callback) {
M
mingxihua 已提交
149
        if (predicates === null || predicates === undefined) {
W
wanning.fang 已提交
150
            return;
S
songruirui 已提交
151
        }
152
        rdbStore.update(TBL_NAME, valueBucket, predicates, function (err, ret) {
M
mingxihua 已提交
153
            if (callback !== undefined) {
W
wanning.fang 已提交
154 155 156 157 158
                callback(err, ret);
            }
        });
    }
};
S
songruirui 已提交
159 160
```

S
songruirui 已提交
161
## delete
S
songruirui 已提交
162

S
songruirui 已提交
163
delete?(uri: string, predicates: dataSharePredicates.DataSharePredicates, callback: AsyncCallback&lt;number&gt;): void
S
songruirui 已提交
164

S
修改  
songruirui 已提交
165
在删除数据库记录时服务端回调此接口,该方法可以选择性重写。
S
songruirui 已提交
166

S
修改  
songruirui 已提交
167
**系统能力:**  SystemCapability.DistributedDataManager.DataShare.Provider
S
songruirui 已提交
168

S
songruirui 已提交
169
**参数:**
S
songruirui 已提交
170

171
| 参数名       | 类型                                                     | 必填 | 说明                               |
S
修改  
songruirui 已提交
172 173
| ---------- | ------------------------------------------------------------ | ---- | ---------------------------------- |
| uri        | string                                                       | 是   | 指示要删除的数据的路径。           |
174
| predicates | [dataSharePredicates.DataSharePredicates](js-apis-data-dataSharePredicates.md#datasharepredicates) | 是   | 指示筛选条件。                     |
S
修改  
songruirui 已提交
175
| callback   | AsyncCallback&lt;number&gt;                                  | 是   | 回调函数。返回已删除的数据记录数。 |
S
songruirui 已提交
176 177 178

**示例:**

S
songruirui 已提交
179
```ts
N
niudongyao 已提交
180
import rdb from '@ohos.data.relationalStore';
181

M
mingxihua 已提交
182 183 184
let DB_NAME = 'DB00.db';
let TBL_NAME = 'TBL00';
let DDL_TBL_CREATE = 'CREATE TABLE IF NOT EXISTS '
185
    + TBL_NAME
M
mingxihua 已提交
186
    + ' (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, phoneNumber DOUBLE, isStudent BOOLEAN, Binary BINARY)';
187 188
let rdbStore;

W
wanning.fang 已提交
189
export default class DataShareExtAbility extends DataShareExtensionAbility {
D
duanweiling 已提交
190
    delete(uri, predicates, callback) {
M
mingxihua 已提交
191
        if (predicates === null || predicates === undefined) {
W
wanning.fang 已提交
192
            return;
S
songruirui 已提交
193
        }
W
wanning.fang 已提交
194
        rdbStore.delete(TBL_NAME, predicates, function (err, ret) {
M
mingxihua 已提交
195
            if (callback !== undefined) {
W
wanning.fang 已提交
196 197 198 199 200
                callback(err, ret);
            }
        });
    }
};
S
songruirui 已提交
201 202
```

S
songruirui 已提交
203
## query
S
songruirui 已提交
204

S
songruirui 已提交
205
query?(uri: string, predicates: dataSharePredicates.DataSharePredicates, columns: Array&lt;string&gt;, callback: AsyncCallback&lt;Object&gt;): void
S
songruirui 已提交
206

S
songruirui 已提交
207
在查询数据库时服务端回调此接口,该方法可以选择性重写。
S
songruirui 已提交
208

S
修改  
songruirui 已提交
209
**系统能力:**  SystemCapability.DistributedDataManager.DataShare.Provider
S
songruirui 已提交
210

S
songruirui 已提交
211 212
**参数:**

213
| 参数名 | 类型 | 必填 | 说明 |
S
songruirui 已提交
214 215
| ----- | ------ | ------ | ------ |
| uri | string | 是  | 指示要查询的数据的路径。 |
216
| predicates | [dataSharePredicates.DataSharePredicates](js-apis-data-dataSharePredicates.md#datasharepredicates) | 是  | 指示筛选条件。 |
S
songruirui 已提交
217 218
| columns | Array&lt;string&gt; | 是 | 指示要查询的列。如果此参数为空,则查询所有列。 |
| callback | AsyncCallback&lt;Object&gt; | 是 | 回调函数。返回查询到的结果集。 |
S
songruirui 已提交
219 220 221

**示例:**

S
songruirui 已提交
222
```ts
N
niudongyao 已提交
223
import rdb from '@ohos.data.relationalStore';
224

M
mingxihua 已提交
225 226 227
let DB_NAME = 'DB00.db';
let TBL_NAME = 'TBL00';
let DDL_TBL_CREATE = 'CREATE TABLE IF NOT EXISTS '
228
    + TBL_NAME
M
mingxihua 已提交
229
    + ' (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, phoneNumber DOUBLE, isStudent BOOLEAN, Binary BINARY)';
230 231
let rdbStore;

W
wanning.fang 已提交
232
export default class DataShareExtAbility extends DataShareExtensionAbility {
D
duanweiling 已提交
233
    query(uri, predicates, columns, callback) {
M
mingxihua 已提交
234
        if (predicates === null || predicates === undefined) {
W
wanning.fang 已提交
235
            return;
S
songruirui 已提交
236
        }
W
wanning.fang 已提交
237
        rdbStore.query(TBL_NAME, predicates, columns, function (err, resultSet) {
M
mingxihua 已提交
238
            if (resultSet !== undefined) {
S
srr101 已提交
239
                console.info(`resultSet.rowCount: ${resultSet.rowCount}`);
W
wanning.fang 已提交
240
            }
M
mingxihua 已提交
241
            if (callback !== undefined) {
W
wanning.fang 已提交
242 243 244 245 246
                callback(err, resultSet);
            }
        });
    }
};
S
songruirui 已提交
247 248
```

D
duanweiling 已提交
249
## batchInsert
S
songruirui 已提交
250

D
duanweiling 已提交
251
batchInsert?(uri: string, valueBuckets: Array&lt;ValuesBucket&gt;, callback: AsyncCallback&lt;number&gt;): void
S
songruirui 已提交
252

S
songruirui 已提交
253
在数据库批量插入时服务端回调此接口,该方法可以选择性重写。
S
songruirui 已提交
254

S
修改  
songruirui 已提交
255
**系统能力:**  SystemCapability.DistributedDataManager.DataShare.Provider
S
songruirui 已提交
256

S
songruirui 已提交
257
**参数:**
S
songruirui 已提交
258

259
| 参数名        | 类型                                                     | 必填 | 说明                             |
S
songruirui 已提交
260 261
| ------------ | ------------------------------------------------------------ | ---- | -------------------------------- |
| uri          | string                                                       | 是   | 指示要批量插入的数据的路径。     |
M
m00512953 已提交
262
| valueBuckets | Array&lt;[ValuesBucket](js-apis-data-valuesBucket.md#valuesbucket)&gt; | 是   | 指示要批量插入的数据。           |
S
songruirui 已提交
263
| callback     | AsyncCallback&lt;number&gt;                                  | 是   | 回调函数。返回插入的数据记录数。 |
S
songruirui 已提交
264 265 266

**示例:**

S
songruirui 已提交
267
```ts
N
niudongyao 已提交
268
import rdb from '@ohos.data.relationalStore';
269

M
mingxihua 已提交
270 271 272
let DB_NAME = 'DB00.db';
let TBL_NAME = 'TBL00';
let DDL_TBL_CREATE = 'CREATE TABLE IF NOT EXISTS '
273
    + TBL_NAME
M
mingxihua 已提交
274
    + ' (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, phoneNumber DOUBLE, isStudent BOOLEAN, Binary BINARY)';
275 276
let rdbStore;

W
wanning.fang 已提交
277
export default class DataShareExtAbility extends DataShareExtensionAbility {
Y
yuyaozhi 已提交
278 279 280 281
  batchInsert(uri, valueBuckets, callback) {
    if (valueBuckets === null || valueBuckets.length === undefined) {
      console.error('invalid valueBuckets');
      return;
W
wanning.fang 已提交
282
    }
Y
yuyaozhi 已提交
283 284 285 286 287 288
    rdbStore.batchInsert(TBL_NAME, valueBuckets, function (err, ret) {
      if (callback !== undefined) {
        callback(err, ret);
      }
    });
  };
W
wanning.fang 已提交
289
};
S
songruirui 已提交
290 291
```

S
songruirui 已提交
292
## normalizeUri
S
songruirui 已提交
293

S
songruirui 已提交
294
normalizeUri?(uri: string, callback: AsyncCallback&lt;string&gt;): void
S
songruirui 已提交
295

S
修改  
songruirui 已提交
296
用户给定的URI转换为服务端使用的URI时回调此接口,该方法可以选择性重写。
S
songruirui 已提交
297

S
修改  
songruirui 已提交
298
**系统能力:**  SystemCapability.DistributedDataManager.DataShare.Provider
S
songruirui 已提交
299 300

**参数:**
S
songruirui 已提交
301

302
| 参数名     | 类型                  | 必填 | 说明                    |
S
songruirui 已提交
303
| -------- | --------------------- | ---- | ----------------------- |
S
修改  
songruirui 已提交
304
| uri      | string                | 是   | 指示用户传入的[URI](js-apis-uri.md#uri)。 |
S
修改  
songruirui 已提交
305
| callback | AsyncCallback&lt;string&gt; | 是   | 回调函数。如果支持URI规范化,则返回规范化URI,否则返回空。 |
S
songruirui 已提交
306 307 308

**示例:**

S
songruirui 已提交
309
```ts
W
wanning.fang 已提交
310
export default class DataShareExtAbility extends DataShareExtensionAbility {
D
duanweiling 已提交
311
    normalizeUri(uri, callback) {
M
mingxihua 已提交
312
        let err = {'code':0};
S
srr101 已提交
313
        let ret = `normalize: ${uri}`;
W
wanning.fang 已提交
314 315 316
        callback(err, ret);
    }
};
S
songruirui 已提交
317 318
```

S
songruirui 已提交
319
## denormalizeUri
S
songruirui 已提交
320

S
songruirui 已提交
321
denormalizeUri?(uri: string, callback: AsyncCallback&lt;string&gt;): void
S
songruirui 已提交
322

S
修改  
songruirui 已提交
323
服务端使用的URI转换为用户传入的初始URI时服务端回调此接口,该方法可以选择性重写。
S
songruirui 已提交
324

S
修改  
songruirui 已提交
325
**系统能力:**  SystemCapability.DistributedDataManager.DataShare.Provider
S
songruirui 已提交
326

S
songruirui 已提交
327
**参数:**
S
songruirui 已提交
328

329
| 参数名     | 类型                  | 必填 | 说明                    |
S
songruirui 已提交
330
| -------- | --------------------- | ---- | ----------------------- |
S
修改  
songruirui 已提交
331
| uri      | string                | 是   | 指示服务端使用的[URI](js-apis-uri.md#uri)。 |
S
修改  
songruirui 已提交
332
| callback | AsyncCallback&lt;string&gt; | 是   | 回调函数。如果反规范化成功,则返回反规范化的URI;如果无需进行反规范化,则返回原始URI;若不支持则返回空。 |
S
songruirui 已提交
333 334 335

**示例:**

S
songruirui 已提交
336
```ts
W
wanning.fang 已提交
337
export default class DataShareExtAbility extends DataShareExtensionAbility {
D
duanweiling 已提交
338
    denormalizeUri(uri, callback) {
M
mingxihua 已提交
339
        let err = {'code':0};
S
srr101 已提交
340
        let ret = `denormalize ${uri}`;
W
wanning.fang 已提交
341 342 343
        callback(err, ret);
    }
};
S
songruirui 已提交
344
```