android中对数据操作包含有:
file, sqlite3, Preferences, ContectResolver与ContentProvider前三种数据操作方式都只是针对本应用内数据,程序不能通过这三种方法去操作别的应用内的数据。
android中提供ContectResolver与ContentProvider来操作别的应用程序的数据。

一、 使用方式
一个应用实现ContentProvider来提供内容给别的应用来操作,
一个应用通过ContentResolver来操作别的应用数据,当然在自己的应用中也可以。
1. ContentResolver的获取
通过Context类:
public abstract ContentResolver getContentResolver();


2. ContentResolver常用操作
//查询:public final Cursor query(Uri uri, String[] projection,          String selection, String[] selectionArgs, String sortOrder);//新增public final Uri insert(Uri url, ContentValues values)    //更新 public final int update(Uri uri, ContentValues values, String where,            String[] selectionArgs)//删除public final int delete(Uri url, String where, String[] selectionArgs)       

以上操作实际是通过Uri来匹配ContentProvider, 再由ContentProvider来进行具体操作的。
操作的参数和操作sqlite各函数的参数意义是一样的。

二、实现ContentProvider提供给外界访问
调用者ContentResoler是通过一个Uri来找到相应的ContentProvider的来进行实际操作。
1. Uri概念
一个Uri的样子如:
scheme://authorities/path/id

如电话记录:
public static final Uri CONTENT_URI = Uri.parse("content://call_log/calls");

a.根据scheme不同调用不程序来处理, 常用的:content, android_resource, file, http等
b.authorities是provider定义的,在AndroidManifest.xml中定义
c.path和id就好理解的。

2. Uri定义
创建自己的Uri, 如:
content://com.shguo.statistic/sms

一般数据中都有dir和item两种(当然可定义多个)。为ContentProvider创建息的UriMatcher并添加这两者:
 String AUTHORITY = "com.shguo.statistics";UriMatcher sUriMatcher = new UriMatcher(UriMatcher.NO_MATCH);sUriMatcher.addURI(AUTHORITY, "sms",  SMS_DIR);   //SMS_DIR = 1sUriMatcher.addURI(AUTHORITY, "sms/#", SMS_ITEM); //SMS_ITEM = 2

contentProvider要根据传入uri判断是dir还是item来操作的。
switch (sUriMatcher.match(uri)) 

来分步操作.

3. 定义MIME类型,
覆盖getType方法:主要是根据uri来返回Provider的MIME类型
 public static final String CONTENT_TYPE = "vnd.android.cursor.dir/vnd.shguo.sms";public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/vnd.shguo.sms";

getType()为:
 switch (sUriMatcher.match(uri)) {case SMS_DIR:return CONTENT_TYPE;case SMS_ITEM:return CONTENT_ITEM_TYPE;default:throw new IllegalArgumentException("Unknown URI " + uri);}


4. 实现query, insert, delete, update四个操作。
具体的实现可以用sqlite, file等。并根据uri分情况操作。
a. query时如果是item加查询条件id.
where = "_ID=" + uri.getPathSegments().get(1) + (!TextUtils.isEmpty(where) ? " AND (" + where + ')' : "";
最后要加上
cursor.setNotificationUri(getContext().getContentResolver(), uri);

b. insert时要求uri只能是dir. 成功之后返回一个加id的uri.
Uri insertUri = ContentUris.withAppendedId(CONTENT_URI, rowId);

c. update、delete与query差不多。
//注意通知注册uri的观察者。getContext().getContentResolver().notifyChange(uri, null);


5. 在AndroidManifest.xml中定义
provider元素,主要属性有:
 name => ContentProvider类名authorities => content type的授权部分multiprocess => true允许在每个客户进程中创建provider实例,消除执行IPC的需求。

更多相关文章

  1. mybatisplus的坑 insert标签insert into select无参数问题的解决
  2. python起点网月票榜字体反爬案例
  3. 传智播客Android视频教程——第五天
  4. android Intent机制详解
  5. android 的短信数据库的读取
  6. Android中的五大存储
  7. android国际化操作
  8. Xamarin.Android使用教程之创建第一个Android应用程序
  9. Android(安卓)- 文件读写操作 总结

随机推荐

  1. Adobe不再为Android提供Flash,移动Flash死
  2. Android(安卓)阴影问题汇总
  3. 实现了 Android 设备之间通过 Wifi 传输
  4. Android(安卓)工具:ADB 使用总结
  5. Android第一讲小结
  6. Android 开发者的下半场
  7. 理解Android回调函数
  8. 【转载】Android数据库事务浅析
  9. 深入理解Android-Init理解
  10. Android移植到VirtualBox及详细流程