ContentProvider类的解析
一、ContentProvider类
1.作用:专门用于不同应用之间进行数据共享的方式。
二、实现方法
1.创建ContenteProvider类
步骤一:继承ContentProvider接口,重写接口的方法
/*其他方法都好理解*/
public class BookProvider extends ContentProvider { @Override
public boolean onCreate() {
return false;
} @Nullable
@Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
return null;
} @Nullable
@Override
/*返回一个Uri请求所对应的MIME类型,如果不关心可直接返回null*/
public String getType(Uri uri) {
return null;
} @Nullable
@Override
public Uri insert(Uri uri, ContentValues values) {
return null;
} @Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
return 0;
} @Override
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
return 0;
}
}
步骤二:在AndroidManifest.xml中注册
<provider
android:authorities="com.chen.android.provider"
android:name=".BookProvider"
android:process=":provider">
</provider>
其中android:authorities是Provider的唯一标识,外界应用必须声明相应的权限才能进行操作。
2.应用访问该ContentProvider
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Uri uri = Uri.parse("content://com.chen.android.provider");
getContentResolver().query(uri,null,null,null,null);
}
content://com.chen.android.provider:唯一标识了BookProvider属性。
通过Activity的ContentProvider管理器,利用Uri指定ContentProvider,并调用指定方法。
注:方法的调用是在Binder线程中的,而不是在Activity的onCreate()方法中
3.创建数据库(辅助)
如何创建数据库:SQLite的使用 和 第一行代码的示例
注:创建了名为Book和User两个Table
public class DbOpenHelper extends SQLiteOpenHelper {
private static final String DBNAME = "book_provider.db";
public static final String BOOK_TABLE_NAME = "book";
public static final String USER_TABLE_NAME = "user";
private String CREATE_BOOK_TABLE = "create table if ont exists"+BOOK_TABLE_NAME+"(_id INTEGER PRIMARY KEY,name TEXT)";
private String CREATE_USER_TABLE = "create table if not exists"+USER_TABLE_NAME
+"(_id INTEGER PRIMARY KEY,"+"name TEXT)";
public DbOpenHelper(Context context, int version) {
super(context, DBNAME, null, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_USER_TABLE);
db.execSQL(CREATE_BOOK_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
4.利用ContentProvider访问其中一个Table
为了知道外界访问是哪一张表,需要定义单独的Uri和Uri_Code,让Uri和Uri_Code相连。
利用UriMatch的addURI方法将两者关联起来。
/*
*BookProvider类中
*/ private static final String AUTHORY = "com.chen.android.provider";
private static final int BOOK_URL_CODE = 0;
private static final int USER_URL_CODE = 1;
private static final UriMatcher mUriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
//稍后用到这个变量
private String tableName;
@Override
public boolean onCreate() {
//访问权限之后为访问Book的地址(content://com.chen.android.provider/book),如果对则返回BOOK_URL_CODE
mUriMatcher.addURI(AUTHORY,"book",BOOK_URL_CODE);
//同上
mUriMatcher.addURI(AUTHORY,"user",USER_URL_CODE);
return false;
}
获取客户端要访问的Table
//步骤一:利用客户端的uri选择出table名
public String getTableName(Uri uri){
String tableName = null;
switch (mUriMatcher.match(uri)){
case BOOK_URL_CODE:
tableName = DbOpenHelper.BOOK_TABLE_NAME;
break;
case USER_URL_CODE:
tableName = DbOpenHelper.USER_TABLE_NAME;
break;
}
return tableName;
}
//步骤二:在ContentProvider中创建DbOpenHelper
private DbOpenHelper mDbOpenHelper;
private Context mContext; @Override
public boolean onCreate() {
....
mContext = getContext();
mDbOpenHelper = new DbOpenHelper(mContext,1);
return false;
}
//步骤三:利用ContentProvider的query()其他方法也是一样的形式
@Nullable
@Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
table = getTableName(uri);
return mDbOpenHelper.getWritableDatabase().query(table,projection,selection,selectionArgs,null,null,sortOrder,null);
}
客户端:将Uri uri = Uri.parse("content://com.chen.android.provider");
改写成Uri uri = Uri.parse("content://com.chen.android.provider/book"); 这样就可以访问BookTable了
注:update、insert、delete会引起源数据的改变,需要通过ContentProvider通知外界改变
5.ContentProvider通知外界数据改变(暂时不知道怎么用)
registerContentObserver:注册观察者
unRegisterContentObserver:取消观察者
notifyChanged:通知当前数据发生改变
ContentProvider类的解析的更多相关文章
- 如何利用.Net内置类,解析未知复杂Json对象
如何利用.Net内置类,解析未知复杂Json对象 如果你乐意,当然可以使用强大的第三方类库Json.Net中的JObject类解析复杂Json字串 . 我不太希望引入第三方类库,所以在.Net内置类J ...
- Java 8 Optional 类深度解析
Java 8 Optional 类深度解析 身为一名Java程序员,大家可能都有这样的经历:调用一个方法得到了返回值却不能直接将返回值作为参数去调用别的方法.我们首先要判断这个返回值是否为null,只 ...
- javap -- Java 类文件解析器
参考文档 http://blog.chinaunix.net/uid-692788-id-2681132.html http://docs.oracle.com/javase/7/docs/techn ...
- 解析HTML文件 - 运用SgmlReader类来解析HTML文件
运用.NET Framework类来解析HTML文件.读取数据并不是最容易的.虽然你可以用.NET Framework中的许多类(如StreamReader)来逐行解析文件,但XmlReader提供的 ...
- 数据:ContentProvider类
一个程序可以通过实现一个Content provider的抽象接口将自己的数据完全暴露出去,而且Content providers是以类似数据库中表的方式将数据暴露. Content provid ...
- Java File类基础解析 1
Java File类基础解析 1 File类的构造方法 public File(String pathname) :通过给定的路径名字符转换为抽象路径名来创建新的File实例 String path ...
- 共享参数ContentProvider 类与数据库绑定,如何通过共享参数测试类,测试数据库的增删改查功能
Intent可以传一个对象 当两个界面之间跳转时,需要传递一个对象过去,是通过使用Bundle类,并且实体类需要serializable实现序列化,传递方法如下: 定义一个静态常量作为key值 pub ...
- 第一个OC类、解析第一个OC程序
01第一个OC 类 本文目录 • 一.语法简介 • 二.用Xcode创建第一个OC的类 • 三.第一个类的代码解析 • 四.添加成员变量 • 五.添加方法 • 六.跟Java的比较 • 七.创建对象 ...
- Spring mybatis源码篇章-NodeHandler实现类具体解析保存Dynamic sql节点信息
前言:通过阅读源码对实现机制进行了解有利于陶冶情操,承接前文Spring mybatis源码篇章-XMLLanguageDriver解析sql包装为SqlSource SqlNode接口类 publi ...
随机推荐
- linux网络编程:使用单进程实现多客户端通信
服务端: //回射服务器 //避免僵尸进程 #include "unistd.h" #include "sys/types.h" #include " ...
- 变形课hd1181(DFS)
变形课 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others)Total Submis ...
- FMDB用法
iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.PlausibleDatabase.sqlitepers ...
- Asp.net MVC 之 ActionResult
Action运行完后,回传的值通过ActionResult 类别或者其衍生的类别操作.ActionResult是一个抽象类,因此,Asp.net MVC 本身就实作了许多不同类型的ActionResu ...
- nginx相关参考博客
http://tengine.taobao.org/book/ http://blog.sina.com.cn/s/articlelist_1929617884_0_1.html http://blo ...
- Callable,Runnable比较及用法
http://blog.csdn.net/xtwolf008/article/details/7713580 http://www.cnblogs.com/whgw/archive/2011/09/2 ...
- winform,wpf全屏 还显示任务栏的解决方法
原文:winform,wpf全屏 还显示任务栏的解决方法 以wpf为例: 全屏代码: this.Topmost = true; this.WindowStyle = System.Windows.Wi ...
- 善待Redis里的数据--Unable to validate object
又是一篇关于姿势的文章,为什么是”又”呢?因为上个星期刚写完一篇关于Apache Commons Pool的正确使用姿势的文章,点击此处阅读. Redis为我们提供便利的同时,我们也要善待里面的数据 ...
- 1.elk 入门示例
zjtest7-frontend:/usr/local/logstash-2.3.4/bin# ./logstash -e 'input{stdin{}} output{stdout{codec=&g ...
- SQL表名,应该用复数还是单数
用单数形式更佳,理由如下: 1.概念直观. 你有一个袋子,里面有好多个苹果,你会说这是个苹果袋.但无论里面有0,1,百万个苹果,它依然是个袋子.表也是如此,表明需要描述清楚,表里面包含的对象,而非有多 ...