js-apis-application-dataShareExtensionAbility.md 12.1 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
| -------- | -------- | -------- | -------- | -------- |
26
| context<sup>10+</sup> | [ExtensionContext](js-apis-inner-application-extensionContext.md)  | 是 | 否 |表示数据共享扩展能力上下文。 |
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
46 47
import relationalStore from '@ohos.data.relationalStore'
import Want from '@ohos.app.ability.Want'
S
songruirui 已提交
48

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

W
wanning.fang 已提交
56
export default class DataShareExtAbility extends DataShareExtensionAbility {
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
  onCreate(want: Want, callback: Function) {
    relationalStore.getRdbStore(globalThis.getContext(), {
      name: DB_NAME,
      securityLevel: relationalStore.SecurityLevel.S1
    }, (err, data) => {
      console.info(`getRdbStore done, data : ${data}`);
      rdbStore = data;
      rdbStore.executeSql(DDL_TBL_CREATE, [], (err) => {
        console.error(`executeSql done, error message : ${err}`);
      });
      if (callback) {
        callback();
      }
    });
  }
W
wanning.fang 已提交
72
};
S
songruirui 已提交
73 74 75 76
```

## insert

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

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

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

**参数:**

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

**示例:**

S
songruirui 已提交
93
```ts
94
import relationalStore from '@ohos.data.relationalStore'
95
import { ValuesBucket } from '@ohos.data.ValuesBucket'
96

M
mingxihua 已提交
97
let TBL_NAME = 'TBL00';
98
let rdbStore: relationalStore.RdbStore;
99

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

S
songruirui 已提交
116
## update
S
songruirui 已提交
117

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

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

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

S
songruirui 已提交
124
**参数:**
S
songruirui 已提交
125

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

**示例:**

S
songruirui 已提交
135
```ts
136
import relationalStore from '@ohos.data.relationalStore';
137 138
import dataSharePredicates from '@ohos.data.dataSharePredicates';
import { ValuesBucket } from '@ohos.data.ValuesBucket'
139

M
mingxihua 已提交
140
let TBL_NAME = 'TBL00';
141
let rdbStore: relationalStore.RdbStore;
142

W
wanning.fang 已提交
143
export default class DataShareExtAbility extends DataShareExtensionAbility {
144 145 146
  update(uri: string, predicates: dataSharePredicates.DataSharePredicates, valueBucket: ValuesBucket, callback: Function) {
    if (predicates === null || predicates === undefined) {
      return;
W
wanning.fang 已提交
147
    }
148 149 150 151 152 153
    rdbStore.update(TBL_NAME, valueBucket, predicates, (err, ret) => {
      if (callback !== undefined) {
        callback(err, ret);
      }
    });
  }
W
wanning.fang 已提交
154
};
S
songruirui 已提交
155 156
```

S
songruirui 已提交
157
## delete
S
songruirui 已提交
158

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

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

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

S
songruirui 已提交
165
**参数:**
S
songruirui 已提交
166

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

**示例:**

S
songruirui 已提交
175
```ts
176
import relationalStore from '@ohos.data.relationalStore';
177
import dataSharePredicates from '@ohos.data.dataSharePredicates';
178

M
mingxihua 已提交
179
let TBL_NAME = 'TBL00';
180
let rdbStore: relationalStore.RdbStore;
181

W
wanning.fang 已提交
182
export default class DataShareExtAbility extends DataShareExtensionAbility {
183 184 185
  delete(uri: string, predicates: dataSharePredicates.DataSharePredicates, callback: Function) {
    if (predicates === null || predicates === undefined) {
      return;
W
wanning.fang 已提交
186
    }
187 188 189 190 191 192
    rdbStore.delete(TBL_NAME, predicates, (err, ret) => {
      if (callback !== undefined) {
        callback(err, ret);
      }
    });
  }
W
wanning.fang 已提交
193
};
S
songruirui 已提交
194 195
```

S
songruirui 已提交
196
## query
S
songruirui 已提交
197

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

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

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

S
songruirui 已提交
204 205
**参数:**

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

**示例:**

S
songruirui 已提交
215
```ts
216
import relationalStore from '@ohos.data.relationalStore';
217
import dataSharePredicates from '@ohos.data.dataSharePredicates';
218

M
mingxihua 已提交
219
let TBL_NAME = 'TBL00';
220
let rdbStore: relationalStore.RdbStore;
221

W
wanning.fang 已提交
222
export default class DataShareExtAbility extends DataShareExtensionAbility {
223 224 225
  query(uri: string, predicates: dataSharePredicates.DataSharePredicates, columns: Array<string>, callback: Function) {
    if (predicates === null || predicates === undefined) {
      return;
W
wanning.fang 已提交
226
    }
227 228 229 230 231 232 233 234 235
    rdbStore.query(TBL_NAME, predicates, columns, (err, resultSet) => {
      if (resultSet !== undefined) {
        console.info(`resultSet.rowCount: ${resultSet.rowCount}`);
      }
      if (callback !== undefined) {
        callback(err, resultSet);
      }
    });
  }
W
wanning.fang 已提交
236
};
S
songruirui 已提交
237 238
```

D
duanweiling 已提交
239
## batchInsert
S
songruirui 已提交
240

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

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

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

S
songruirui 已提交
247
**参数:**
S
songruirui 已提交
248

249
| 参数名        | 类型                                                     | 必填 | 说明                             |
S
songruirui 已提交
250 251
| ------------ | ------------------------------------------------------------ | ---- | -------------------------------- |
| uri          | string                                                       | 是   | 指示要批量插入的数据的路径。     |
M
m00512953 已提交
252
| valueBuckets | Array&lt;[ValuesBucket](js-apis-data-valuesBucket.md#valuesbucket)&gt; | 是   | 指示要批量插入的数据。           |
S
songruirui 已提交
253
| callback     | AsyncCallback&lt;number&gt;                                  | 是   | 回调函数。返回插入的数据记录数。 |
S
songruirui 已提交
254 255 256

**示例:**

S
songruirui 已提交
257
```ts
258
import relationalStore from '@ohos.data.relationalStore';
259
import { ValuesBucket } from '@ohos.data.ValuesBucket'
260

M
mingxihua 已提交
261
let TBL_NAME = 'TBL00';
262
let rdbStore: relationalStore.RdbStore;
263

W
wanning.fang 已提交
264
export default class DataShareExtAbility extends DataShareExtensionAbility {
265
  batchInsert(uri: string, valueBuckets: Array<ValuesBucket>, callback: Function) {
Y
yuyaozhi 已提交
266 267 268
    if (valueBuckets === null || valueBuckets.length === undefined) {
      console.error('invalid valueBuckets');
      return;
W
wanning.fang 已提交
269
    }
270
    rdbStore.batchInsert(TBL_NAME, valueBuckets, (err, ret) => {
Y
yuyaozhi 已提交
271 272 273 274 275
      if (callback !== undefined) {
        callback(err, ret);
      }
    });
  };
W
wanning.fang 已提交
276
};
S
songruirui 已提交
277 278
```

S
songruirui 已提交
279
## normalizeUri
S
songruirui 已提交
280

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

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

S
修改  
songruirui 已提交
285
**系统能力:**  SystemCapability.DistributedDataManager.DataShare.Provider
S
songruirui 已提交
286 287

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

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

**示例:**

S
songruirui 已提交
296
```ts
297 298
import { BusinessError } from '@ohos.base'

W
wanning.fang 已提交
299
export default class DataShareExtAbility extends DataShareExtensionAbility {
300 301 302 303 304 305 306 307 308 309 310
  normalizeUri(uri: string, callback: Function) {
    let key = 'code';
    let value = 0;
    let err: BusinessError = {
      code: value,
      name: key,
      message: key
    };
    let ret: string = `normalize: ${uri}`;
    callback(err, ret);
  }
W
wanning.fang 已提交
311
};
S
songruirui 已提交
312 313
```

S
songruirui 已提交
314
## denormalizeUri
S
songruirui 已提交
315

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

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

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

S
songruirui 已提交
322
**参数:**
S
songruirui 已提交
323

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

**示例:**

S
songruirui 已提交
331
```ts
332 333
import { BusinessError } from '@ohos.base'

W
wanning.fang 已提交
334
export default class DataShareExtAbility extends DataShareExtensionAbility {
335 336 337 338 339 340 341 342 343 344 345
  denormalizeUri(uri: string, callback: Function) {
    let key = 'code';
    let value = 0;
    let err: BusinessError = {
      code: value,
      name: key,
      message: key
    };
      let ret = `denormalize ${uri}`;
      callback(err, ret);
  }
W
wanning.fang 已提交
346
};
S
songruirui 已提交
347
```