Android 组件ContentProvider

Android的数据存储有五种方式Shared Preferences、网络存储、文件存储、外储存储、SQLite,一般这些存储都只是在单独的一个应用程序之中达到一个数据的共享,有时候我们需要操作其他应用程序的一些数据,例如常见系统里的通讯录,短信,照片等等,所以云存储,通讯录,艳照门等等就孕育而生了。ContentProvider可以理解成内容提供者,也可以理解为一个接口,就是提供了一个供外部访问的接口,有的时候需要进行权限控制。

ContentProvider简介

ContentProvider向我们提供了我们在应用程序之前共享数据的一种机制,而我们知道每一个应用程序都是运行在不同的应用程序的,不同程序的之间数据共享是现实的需要,程序总不能使闭环的,Android中的ContentProvider外共享数据的好处是统一了数据的访问方式。简单总结说下:

ContentProvider为存储和获取数据提供了统一的接口。ContentProvide对数据进行封装,不用关心数据存储的细节。使用表的形式来组织数据。使用ContentProvider可以在不同的应用程序之间共享数据。 Android为常见的一些数据提供了默认的ContentProvider(包括音频、视频、图片和通讯录等)。

说到了ContentProvider这么多好处,不能不说下Uri(Universal Resource Identifier)注意不是URL,通用资源标识符,看个简单的读取联系人的Uri,content://contacts/people,

content://是前缀,固定的;contacts 主机名(或叫Authority)用于唯一标识这个ContentProvider,外部调用者可以根据这个标识来调用;people  路径(path)表示我们要操作的数据,路径的构建根据业务而定;

自定义ContentProvider

俗话说,欲善其事必先利其器,想要成为一个内容提供者,就先需要有数据,先建立一个SqlDbConncetion:

view sourceprint?

01.public
class SqlDBConnection extends
SQLiteOpenHelper {

02.

03.private
static final
String DbName =
"Book.db";

04.private
static int
version=
1;

05.

06.public
SqlDBConnection(Context context) {

07.super(context, DbName,
null, version);

08.}

09.

10.@Override

11.public
void onCreate(SQLiteDatabase db) {

12.// TODO Auto-generated method stub

13.String sqlString="create table Book (id integer primary key autoincrement,Name nvarchar(200),Title
nvarchar(200))"
;

14.db.execSQL(sqlString);

15.}

16.

17.@Override

18.public
void onUpgrade(SQLiteDatabase db,
int oldVersion, int
newVersion) {

19.// TODO Auto-generated method stub

20.}

21.}

  上篇文章讲的junit测试这个时候可以拿过来使用一下初始化下数据:

view sourceprint?

01.public
class BookCase extends
AndroidTestCase {

02.

03.public
void Intial() {

04.SqlDBConnection dbConnection =
new SqlDBConnection(getContext());

05.SQLiteDatabase sqlDataBase = dbConnection.getWritableDatabase();

06.long
row = 0;

07.for
(int
i =
0; i < 5; i++) {

08.ContentValues values =
new ContentValues();

09.values.put("Name",
"书籍"+i);

10.values.put("Title",
"标题" + i);

11.row = sqlDataBase.insert("Book",
null, values);

12.Log.i("BookCase",
"插入成功:" + row);

13.}

14.}

15.}

 前面是基础工作,这个时候就可以建立一个自己的ContentProvider:

expand source

 主机名是需要自己去AndroidManifest.xml文件中自己配置的,要求是唯一的,最好是用包名就好:

view sourceprint?

1.<provider android:name="com.example.googlecontentprovider.MyContentProvider"

2.android:authorities="com.example.googlecontentprovider.MyContentProvider"></provider>

  如果觉得上面的那一串代码不是很好理解,下面调用的时候我会分别解释。

ContentResolver的使用

方法写在一个应用程序中调用属于正常,在另外一个程序中调用该程序的方法就是类似于接口了,下面先看原来初始化的数据:

重新新建一个Android测试项目,定义为BookCase,首先插入数据,定义一个Uri,这里面主机名就是上面定义的包名,book/insert与CONTENT_INSERT是对应的:

view sourceprint?

01.public
void bookInsert() {

02.Uri uri = Uri

03..parse("content://com.example.googlecontentprovider.MyContentProvider/book/insert");

04.ContentResolver resolver = getContext().getContentResolver();

05.ContentValues values =
new ContentValues();

06.values.put("Name",
"书籍5");

07.values.put("Title",
"标题5");

08.uri = resolver.insert(uri, values);

09.Log.i("BookCase",
"Uri" + uri);

10.long
id = ContentUris.parseId(uri);

11.Log.i("BookCase",
"测试成功" + id);

12.}

  显示结果如下:

然后更新刚才插入的数据,同样的更具Code给Uri赋值,然后初始化一个ContentResolver,调用update方法:

view sourceprint?

01.public
void bookUpdate() {

02.Uri uri = Uri

03..parse("content://com.example.googlecontentprovider.MyContentProvider/book/update");

04.ContentResolver resolver = getContext().getContentResolver();

05.ContentValues values=new
ContentValues();

06.values.put("Name",
"修改");

07.int
count = resolver.update(uri, values, " id=?",new
String[]{"10"});

08.Log.i("BookCase",
"更新了" + count + "行");

09.}

  结果如下:

删除插入的数据:

view sourceprint?

01.public
void bookDelete() {

02.Uri uri = Uri

03..parse("content://com.example.googlecontentprovider.MyContentProvider/book/delete");

04.ContentResolver resolver = getContext().getContentResolver();

05.String where =" id=?";

06.String[] argString = {"10"};

07.int
count = resolver.delete(uri, where, argString);

08.Log.i("BookCase",
"删除了" + count + "行");

09.}

结果如下:

查询所有的数据:

view sourceprint?

01.public
void bookQuery() {

02.Uri uri = Uri

03..parse("content://com.example.googlecontentprovider.MyContentProvider/book/query");

04.ContentResolver resolver = getContext().getContentResolver();

05.Cursor  cursor=resolver.query(uri,
new String[]{"id","Name","Title"},
null, null,
null);

06.if
(cursor.getCount()>0) {

07.while
(cursor.moveToNext()) {

08.int
id=cursor.getInt(cursor.getColumnIndex("Id"));

09.String nameString=cursor.getString(cursor.getColumnIndex("Name"));

10.String titleString=cursor.getString(cursor.getColumnIndex("Title"));

11.Log.i("BookCase", id+"---"+nameString+"---"+titleString);

12.}

13.}

14.

15.}

  Log下的记录:

查询单条记录:

view sourceprint?

01.public
void bookQuerySingle() {

02.Uri uri = Uri

03..parse("content://com.example.googlecontentprovider.MyContentProvider/book/query");

04.ContentResolver resolver = getContext().getContentResolver();

05.uri=ContentUris.withAppendedId(uri,1);

06.Cursor  cursor=resolver.query(uri,
new String[]{"id","Name","Title"},
null, null,
null);

07.if
(cursor.getCount()>0) {

08.while
(cursor.moveToNext()) {

09.int
id=cursor.getInt(cursor.getColumnIndex("Id"));

10.String nameString=cursor.getString(cursor.getColumnIndex("Name"));

11.String titleString=cursor.getString(cursor.getColumnIndex("Title"));

12.Log.i("BookCase", id+"---"+nameString+"---"+titleString);

13.}

14.}

15.}

 结果如图:

时间: 2024-08-27 00:37:46

Android 组件ContentProvider的相关文章

Android组件系列----ContentProvider内容提供者

[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4108017.html 联系方式:[email protected] [正文] 一.ContentProvider简介: ContentProvider内容提供者(四大组件之一)主要用于在不同的应用程序之间实现数据共享的功能. ContentProvider可以理解为一个Android应用对外开放的

Android之ContentProvider

ContentProvider是Android的四大组件之一. 先说说我对这个东西的理解吧,ContentProvider就是用来存数据,用来共享数据的,比如:手机通讯录的联系人的信息以及手机上面存的相片,视频等等. 比较官方的解释: Android中的Content provider机制可支持在多个应用中存储和读取数据.这也是跨应用共享数据的方式之一,还有文件,sharePreference,SQLite数据库等方式存储共享数据库,但是ContentProvider更好的提供了数据共享接口的统

【Android开发精要笔记】Android组件模型解析

Android组件模型解析 Android中的Mashup 将应用切分成不同类别的组件,通过统一的定位模型和接口标准将他们整合在一起,来共同完成某项任务.在Android的Mashup模式下,每个组件的功能都可以被充分的复用.来自不同应用的组件可以有机地结合在一起,共同完成任务. 基于Mashup的Android应用模型 三个基本要素:组件.连接.配置 接口就是实现单元.从代码来看,组件就是派生自特定接口或基类的子类的实现,如界面组件Activity就是指派生自android.app.Activ

Android组件的通讯——Intent

转载:Android组件的通讯-Intent 1.概述 一个应用程序的三个核心组件——activities.services.broadcast receivers,都是通过叫做intents的消息激活.Intent消息是一种同一或不同应用程序中的组件之间延迟运行时绑定的机制.intent本身(是一个Intent对象),是一个被动的数据结构保存一个将要执行的操作的抽象描述,或在广播的情况下,通常是某事已经发生且正在宣告.对于这三种组件,有独立的传送intent的机制: Activity:一个in

解读Android之ContentProvider(2)创建自己的Provider

本文翻译自android官方文档,结合自己测试,整理如下. content provider管理数据的访问,我们可以在自己的应用程序中实现一个或多个自定义的provider(通过继承抽象类ContentProvider),当然这些provider需要在manifest文件中注册.尽管content provider是用来为其它程序来访问数据的,但是在自己程序中的activities显然可以对这些数据进行处理. 创建provider之前注意事项 确定是否需要提供content provider.若

Android组件系列----Activity组件详解

[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/3924567.html 联系方式:[email protected] [正文] 注:四大组件指的是应用组件:Activity.Service.BroadcastReceiver.ContentProvider:之前的控件指的是UI组件. 博文目录: 一.Activity简介 二.Activity的状

Android组件化

附:Android组件化和插件化开发 App组件化与业务拆分那些事 Android项目架构之业务组件化 Android组件化核心之路由实现

Android组件之间的信使——Intent

从一个Activity启动到另一个Activity可以使用startActivity()方法或者是startActivityForResult()方法 第一种:直接启动一个ActivityIntent intent = new Intent(Main.this, SecondActivity.class);startActivity(intent); 第二种:启动另一个Activity并返回结果作用:当从第二个Activity回跳到前一个Activity的时候,就不再需要使用startActiv

Android组件学习之ExpandableListView

一个简单的小例子: 可以展开的ListView,和Listview差不多,只是设置的Adapter不同.常用的Adapter有BaseExpandableListAdapter.SimpleExpandableListAdapter.SimpleCursorTreeAdapter 布局如下:(布局中我设置了android:groupIndicator,不知道为什么不起作用.另外,android:dividerHeight这个属性是组对象和子节点共用的.如果要定义比较复杂的组视图及子节点视图,还是