Data Ability
Data提供方可以自定義數(shù)據(jù)的增、刪、改、查,以及文件打開等功能,并對(duì)外提供這些接口。
Data存儲(chǔ)方式有兩種:
文件數(shù)據(jù):如文本、圖片、音樂等。
結(jié)構(gòu)化數(shù)據(jù):如數(shù)據(jù)庫等。
UserDataAbility
用來接收其他APP發(fā)送的請(qǐng)求,提供外部程序訪問的入口,從而實(shí)現(xiàn)應(yīng)用間的數(shù)據(jù)訪問
實(shí)現(xiàn)UserDataAbility,需要在“Project”窗口當(dāng)前工程的主目錄(“entry > src > main > java > com.xxx.xxx”)選擇“File > New > Ability > Empty Data Ability”,設(shè)置“Data Name”后完成UserDataAbility的創(chuàng)建。
文件存儲(chǔ)
在Data中重寫FileDescriptor openFile
通過uri來獲取
@Override
public FileDescriptor openFile(Uri uri, String mode) throws File NotFoundException {
// 創(chuàng)建messageParcel
MessageParcel messageParcel = MessageParcel.obtain();
File file = new File(uri.getDecodedPathList().get(1));
if (mode == null || !"rw".equals(mode)) {
file.setReadOnly();
}
FileInputStream fileIs = new FileInputStream(file);
FileDescriptor fd = fileIs.getFD();
// 綁定文件描述符
return messageParcel.dupFileDescriptor(fd);
}
數(shù)據(jù)庫存儲(chǔ)
初始化數(shù)據(jù)庫連接。
系統(tǒng)會(huì)在應(yīng)用啟動(dòng)時(shí)調(diào)用onStart()方法創(chuàng)建Data實(shí)例。
private static final String DATABASE_NAME ="UserDataAbility.db";
private static final String DATABASE_NAME_ALIAS = "UserDataAbility";
private static final HiLogLabel LABEL_LOG = new HiLogLabel(HiLog.LOG_APP, 0xD00201, "Data_Log");
private OrmContext ormContext = null;
@Override
public void onStart(Intent intent) {
super.onStart(intent);
DatabaseHelper manager = new DatabaseHelper(this);
ormContext = manager.getOrmContext(DATABASE_NAME_ALIAS, DATABASE_NAME, BookStore.class);
}
查詢數(shù)據(jù)庫
ResultSet query?(Uri uri, String[] columns, DataAbilityPredicates predicates)
向數(shù)據(jù)庫中插入單條數(shù)據(jù)
int insert?(Uri uri, ValuesBucket value)
向數(shù)據(jù)庫中插入多條數(shù)據(jù)
int batchInsert?(Uri uri, ValuesBucket[] values)
刪除一條或多條數(shù)據(jù)
int delete?(Uri uri, DataAbilityPredicates predicates)
更新數(shù)據(jù)庫
int update?(Uri uri, ValuesBucket value, DataAbilityPredicates predicates)
批量操作數(shù)據(jù)庫
DataAbilityResult[] executeBatch?(ArrayList<DataAbilityOperation> operations)