ContentProvider详解
作用:把一个App中的数据库通过Url的形式共享出来,供其他App使用。
首先在App1中创建一个数据库,用SQLiteOpenHelper
public class MyOpenHelper extends SQLiteOpenHelper {
public MyOpenHelper(Context context){
super(context,"Account.db",null,1);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table info(_id integer primary key autoincrement, name varchar(20),money varchar(10))");
db.execSQL("insert into info(name, money) values(?,?)",new String[]{"张三","5000"});
ContentValues cv = new ContentValues();
cv.put("name","李四");
cv.put("money","6000");
db.insert("info",null,cv);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
创建数据库:
MyOpenHelper myOpenHelper = new MyOpenHelper(this); myOpenHelper.getReadableDatabase();
然后用过ContentProvider把数据库共享出来,首先看代码:
public class MyProvider extends ContentProvider {
//定义一个Uri路径匹配器 (匹配不成功的时候会返回一个NO_MATCH返回一个-1)
private static final UriMatcher sURIMatcher = new UriMatcher(UriMatcher.NO_MATCH);
private static final int QUERYSUCESS = 0;
private static final int INSERTSUCESS = 1;
private static final int UPADTESUCESS = 2;
private static final int DELETESUCESS = 3;
//创建一个静态代码块,在这里添加Uri
static {
/**
* authority 注意:和清单文件里面定义的一样 com.coderwei.provider/query
*/
sURIMatcher.addURI("com.coderwei.provider","query",QUERYSUCESS );
sURIMatcher.addURI("com.coderwei.provider","insert",INSERTSUCESS );
sURIMatcher.addURI("com.coderwei.provider","update",UPADTESUCESS );
sURIMatcher.addURI("com.coderwei.provider","delete",DELETESUCESS );
}
private MyOpenHelper myOpenHelper;
@Override
public boolean onCreate() {
//初始化MyOpenHelper
myOpenHelper = new MyOpenHelper(getContext());
return false;
}
@Nullable
@Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
if (sURIMatcher.match(uri)==QUERYSUCESS){
//说明路径匹配成功
SQLiteDatabase db = myOpenHelper.getReadableDatabase();
Cursor cursor = db.query("info",projection,selection,selectionArgs,null,null,sortOrder);
//db.close();
//这里不能关闭Cursor
return cursor;
}else {
throw new IllegalArgumentException("uri路径不匹配");
}
}
@Nullable
@Override
public String getType(Uri uri) {
return null;
}
@Nullable
@Override
public Uri insert(Uri uri, ContentValues values) {
if (sURIMatcher.match(uri)==INSERTSUCESS){
SQLiteDatabase db = myOpenHelper.getReadableDatabase();
long insert = db.insert("info",null,values);
Uri uri1 = Uri.parse("com.coderwei.insert/"+insert);
//db.close();
return uri1;
}else {
throw new IllegalArgumentException("uri路径不匹配");
}
}
@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
if (sURIMatcher.match(uri)==DELETESUCESS){
SQLiteDatabase db = myOpenHelper.getReadableDatabase();
int delete = db.delete("info",selection,selectionArgs);
//db.close();
return delete;
}else {
throw new IllegalArgumentException("uri路径不匹配");
}
}
@Override
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
if (sURIMatcher.match(uri)== UPADTESUCESS){
SQLiteDatabase db = myOpenHelper.getReadableDatabase();
int update = db.update("info",values,selection,selectionArgs);
//db.close();
return update;
}else {
throw new IllegalArgumentException("uri路径不匹配");
}
}
}
代码很长,但是很简单,主要把上面四个增删改查方法实现就行,上面的db.close()关闭的时候报错了,所以就注释掉了,关不关都可以。
Insert方法返回的是一个Url对象,直接自己写一个就行了。
记得在Manifest.xml中配置ContentProvider:
<provider
android:authorities="com.coderwei.provider"
android:exported="true"
android:name=".MyProvider">
</provider>
android:authorities 自己随便给一个字符串,
android:exported="true"一定要写上这句,这句话表示可以被另一个Application的组件启动,没写可能会报错。
sURIMatcher.addURI("com.coderwei.provider","query",QUERYSUCESS );中的com.coderwei.provider就是这个字符串。
然后就是来到App2了,先看代码:
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
public void click1(View v){
doQuery();
}
public void click2(View v){
doInsert();
}
public void click3(View v){
doDelete();
}
public void click4(View v){
doUpdate();
}
private void doQuery(){
Uri uri = Uri.parse("content://com.coderwei.provider/query");
Cursor cursor = getContentResolver().query(uri,new String[]{"name","money"},null,null,null);
if (cursor!=null){
while (cursor.moveToNext()){
String name = cursor.getString(0);
String money = cursor.getString(1);
System.out.println("name:"+name+" money: "+money);
}
}
}
private void doInsert(){
Uri uri = Uri.parse("content://com.coderwei.provider/insert");
ContentValues cv = new ContentValues();
cv.put("name","王五");
cv.put("money","800");
Uri uri1 = getContentResolver().insert(uri,cv);
System.out.println("插入uri1:"+uri1);
}
private void doDelete(){
Uri uri = Uri.parse("content://com.coderwei.provider/delete");
int delete = getContentResolver().delete(uri,"name=?",new String[]{"王五"});
System.out.print("刪除了: "+delete);
}
private void doUpdate(){
Uri uri = Uri.parse("content://com.coderwei.provider/update");
ContentValues cv = new ContentValues();
cv.put("money","9000");
int update = getContentResolver().update(uri,cv,"name=?",new String[]{"王五"});
System.out.println("更新了:"+update);
}
}
里面就是四个增删改查方法,就Query稍微麻烦一点,查询的结果返回一个Cursor对象,然后把这个Cursor对象的内容取出来就行了,
ContentProvider详解的更多相关文章
- Android开发数据存储之ContentProvider详解
转载:十二.ContentProvider和Uri详解 一.使用ContentProvider(内容提供者)共享数据 ContentProvider在android中的作用是对外共享数据,也就是说你可 ...
- 【转】android四大组件--ContentProvider详解
一.相关ContentProvider概念解析: 1.ContentProvider简介在Android官方指出的Android的数据存储方式总共有五种,分别是:Shared Preferences. ...
- Android四大组件--ContentProvider详解(转)
一.相关ContentProvider概念解析: 1.ContentProvider简介在Android官方指出的Android的数据存储方式总共有五种,分别是:Shared Preferences. ...
- Android面试收集录3 ContentProvider详解
1.ContentProvider简单介绍 1.1.定义 ContentProvider,即内容提供者属于Android的四大组件之一. 1.2.作用 进程间进行数据交互&共享,即跨进程通信. ...
- Android ContentProvider详解
1.概述 ContentProvider以Uri的形式对外提供数据,允许其他应用程序访问或者修改数据.也就是说你可以通过ContentProvider把应用中的数据共享给其他应用访问,其他应用可以通过 ...
- ContentProvider数据访问详解
ContentProvider数据访问详解 Android官方指出的数据存储方式总共有五种:Shared Preferences.网络存储.文件存储.外储存储.SQLite,这些存储方式一般都只是在一 ...
- Android ContentProvider 基本原理和使用详解
ContentProvider(内容提供者)是 Android 的四大组件之一,管理 Android 以结构化方式存放的数据,以相对安全的方式封装数据(表)并且提供简易的处理机制和统一的访问接口供其他 ...
- Android proguard 详解
本文转载于:http://blog.csdn.net/banketree/article/details/41928175 简介 Java代码是非常容易反编译的.为了很好的保护Java源代码,我们往往 ...
- [转]AndroidManifest.xml文件详解
转自:http://www.cnblogs.com/greatverve/archive/2012/05/08/AndroidManifest-xml.html AndroidManifest.xml ...
随机推荐
- 使用VIM插件ctags来阅读C代码
说明 Ctags是vim下方便代码阅读的工具.尽管ctags也可以支持其它编辑器,但是它正式支持的只有vim.并且vim中已经默认安装ctags,它可以帮助程序员很容易地浏览源代码:ctags最先是用 ...
- hadoop2.6.2分布式环境搭建
1.准备三台机器,机器名是:master.slave01.slave02 1.1 最小化安装centos6.5 1.2 安装ssh,yum -y install openssh-clients(这一步 ...
- SSH 整合及注意事项
Spring 整合 hibernate 配置 1. spring 配置管理datasource 及 sessionFactory 1) 引入相关jdbc配置文件. <context:proper ...
- 重写成员“log4net.Util.ReadOnlyPropertiesDictionary.GetObjectData(System.Runtime.Serialization.SerializationInfo, System.Runtime.Serialization.StreamingContext)”时违反了继承安全性规则
在.NET 4.0下使用最新版本的log4Net 1.2.10,会遇到下面这样的错误: 重写成员“log4net.Util.ReadOnlyPropertiesDictionary.GetObject ...
- accp7.0优化MySchool数据库设计内测笔试题总结
1) 在SQL Server 中,为数据库表建立索引能够(C ). 索引:是SQL SERVER编排数据的内部方法,是检索表中数据的直接通道 建立索引的作用:大大提高了数据库的检索速度,改善数据库性能 ...
- maven总结5
上篇文章中项目最终发布的release仓库和快照仓库都是nexus的默认仓库,若所有的本地开发项目版本都发布到同一个仓库,可能会造成冲突.因此,我们可以为每一个项目创建一组仓库(快照版本和releas ...
- NOIP1999 旅行家的预算
题目描述 一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的).给定两个城市之间的距离D1.汽车油箱的容量C(以升为单位).每升汽油能行驶的距离D2.出发点每升汽油价格P和沿 ...
- bzoj2548[Cstc2002]灭鼠行动
Description 最近,有一些繁殖力很强的老鼠在下水道非常猖獗,灭鼠特工队正在计划消灭这些老鼠.下水道只有东西方向和南北方向的管道,如图所示. 灭鼠特工队的队员拥有强大的武器.他们将在某些时刻t ...
- 直接拿来用!最火的Android开源项目(完结篇)
直接拿来用!最火的Android开源项目(完结篇) 2014-01-06 19:59 4785人阅读 评论(1) 收藏 举报 分类: android 高手进阶教程(100) 摘要:截至目前,在GitH ...
- 关于Ajax中http协议
关于ajaxajax是异步的JavaScript和XML,优点是无刷新的与后天通信并获取数据,只更改页面中需要更改的部分,而不是刷新整个页面,减少无意义的数据传输,提高了效率和用户体验 1.协议和HT ...