contentprovider的学习实例总结

上传人:平*** 文档编号:13294588 上传时间:2017-10-23 格式:DOCX 页数:8 大小:36.25KB
返回 下载 相关 举报
contentprovider的学习实例总结_第1页
第1页 / 共8页
contentprovider的学习实例总结_第2页
第2页 / 共8页
contentprovider的学习实例总结_第3页
第3页 / 共8页
contentprovider的学习实例总结_第4页
第4页 / 共8页
contentprovider的学习实例总结_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《contentprovider的学习实例总结》由会员分享,可在线阅读,更多相关《contentprovider的学习实例总结(8页珍藏版)》请在金锄头文库上搜索。

1、工作中遇到了 contentprovider 数据共享机制,下面来总结一下:一、ContentProvider 简介当应用继承 ContentProvider 类,并重写该类用于提供数据和存储数据的方法,就可以向其他应用共享其数据。虽然使用其他方法也可以对外共享数据,但数据访问方式会因数据存储的方式而不同,如:采用文件方式对外共享数据,需要进行文件操作读写数据;采用 sharedpreferences 共享数据,需要使用 sharedpreferences API 读写数据。而使用 ContentProvider 共享数据的好处是统一了数据访问方式。二、Uri 类简介Uri 代表了要操作的数据

2、, Uri 主要包含了两部分信息:1.需要操作的 ContentProvider ,2.对ContentProvider 中的什么数据进行操作,一个 Uri 由以下几部分组成:1.scheme:ContentProvider(内容提供者)的 scheme 已经由 Android 所规定为:content:/。2.主机名(或 Authority):用于唯一标识这个 ContentProvider,外部调用者可以根据这个标识来找到它。3.路径( path):可以用来表示我们要操作的数据,路径的构建应根据业务而定,如下: 要操作 contact 表中 id 为 10 的记录,可以构建这样的路径:/c

3、ontact/10 要操作 contact 表中 id 为 10 的记录的 name 字段, contact/10/name 要操作 contact 表中的所有记录,可以构建这样的路径:/contact要操作的数据不一定来自数据库,也可以是文件等他存储方式,如下:要操作 xml 文件中 contact 节点下的 name 节点,可以构建这样的路径:/contact/name如果要把一个字符串转换成 Uri,可以使用 Uri 类中的 parse()方法,如下:Uri uri = Uri.parse(content:/com.changcheng.provider.contactprovider/

4、contact)三、UriMatcher 、ContentUrist 和 ContentResolver 简介因为 Uri 代表了要操作的数据,所以我们很经常需要解析 Uri,并从 Uri 中获取数据。Android 系统提供了两个用于操作 Uri 的工具类,分别为 UriMatcher 和 ContentUris 。掌握它们的使用,会便于我们的开发工作。UriMatcher:用于匹配 Uri,它的用法如下:1.首先把你需要匹配 Uri 路径全部给注册上,如下:/常量 UriMatcher.NO_MATCH 表示不匹配任何路径的返回码(-1) 。UriMatcher uriMatcher =

5、new UriMatcher(UriMatcher.NO_MATCH);/如果 match()方法匹配content:/com.changcheng.sqlite.provider.contactprovider/contact 路径,返回匹配码为 1uriMatcher.addURI(“com.changcheng.sqlite.provider.contactprovider”, “contact”, 1);/添加需要匹配 uri,如果匹配就会返回匹配码 /如果 match()方法匹配 content:/com.changcheng.sqlite.provider.contactprovi

6、der/contact/230 路径,返回匹配码为2uriMatcher.addURI(“com.changcheng.sqlite.provider.contactprovider”, “contact/#”, 2);/#号为通配符2.注册完需要匹配的 Uri 后,就可以使用 uriMatcher.match(uri)方法对输入的 Uri 进行匹配,如果匹配就返回匹配码,匹配码是调用 addURI()方法传入的第三个参数,假设匹配content:/com.changcheng.sqlite.provider.contactprovider/contact 路径,返回的匹配码为 1。Conte

7、ntUris:用于获取 Uri 路径后面的 ID 部分,它有两个比较实用的方法: withAppendedId(uri, id)用于为路径加上 ID 部分 parseId(uri)方法用于从路径中获取 ID 部分ContentResolver:当外部应用需要对 ContentProvider 中的数据进行添加、删除、修改和查询操作时,可以使用 ContentResolver 类来完成,要获取 ContentResolver 对象,可以使用 Activity提供的 getContentResolver()方法。 ContentResolver 使用 insert、delete、update、qu

8、ery 方法,来操作数据。四、ContentProvider 示例程序Manifest.xml 中的代码:?12345678910111213141516需要在中为 provider 进行注册!首先定义一个数据库的工具类:?12345678910111213141516171819202122public class RuiXin public static final String DBNAME = ruixinonlinedb; public static final String TNAME = ruixinonline;public static final int VERSION =

9、 3;public static String TID = tid;public static final String EMAIL = email;public static final String USERNAME = username;public static final String DATE = date;public static final String SEX = sex;public static final String AUTOHORITY = com.ruixin.login;public static final int ITEM = 1;public stati

10、c final int ITEM_ID = 2;public static final String CONTENT_TYPE = vnd.android.cursor.dir/vnd.ruixin.login;public static final String CONTENT_ITEM_TYPE = vnd.android.cursor.item/vnd.ruixin.login;public static final Uri CONTENT_URI = Uri.parse(content:/ + AUTOHORITY + /ruixinonline);1. 然后创建一个数据库:?1234

11、56789101112131415161718public class DBlite extends SQLiteOpenHelper public DBlite(Context context) super(context, RuiXin.DBNAME, null, RuiXin.VERSION);/ TODO Auto-generated constructor stubOverridepublic void onCreate(SQLiteDatabase db) / TODO Auto-generated method stubdb.execSQL(create table +RuiXi

12、n.TNAME+( +RuiXin.TID+ integer primary key autoincrement not null,+RuiXin.EMAIL+ text not null, +RuiXin.USERNAME+ text not null, +RuiXin.DATE+ interger not null,+RuiXin.SEX+ text not null););Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) / TODO Auto-generated method

13、 stub1920212223242526272829public void add(String email,String username,String date,String sex)SQLiteDatabase db = getWritableDatabase();ContentValues values = new ContentValues();values.put(RuiXin.EMAIL, email);values.put(RuiXin.USERNAME, username);values.put(RuiXin.DATE, date);values.put(RuiXin.SE

14、X, sex);db.insert(RuiXin.TNAME,values);1. 接着创建一个 Myprovider.java 对数据库的接口进行包装:?123456789101112131415161718192021222324252627282930public class MyProvider extends ContentProviderDBlite dBlite;SQLiteDatabase db;private static final UriMatcher sMatcher;staticsMatcher = new UriMatcher(UriMatcher.NO_MATCH

15、);sMatcher.addURI(RuiXin.AUTOHORITY,RuiXin.TNAME, RuiXin.ITEM);sMatcher.addURI(RuiXin.AUTOHORITY, RuiXin.TNAME+/#, RuiXin.ITEM_ID);Overridepublic int delete(Uri uri, String selection, String selectionArgs) / TODO Auto-generated method stubdb = dBlite.getWritableDatabase();int count = 0;switch (sMatc

16、her.match(uri) case RuiXin.ITEM:count = db.delete(RuiXin.TNAME,selection, selectionArgs);break;case RuiXin.ITEM_ID:String id = uri.getPathSegments().get(1);count = db.delete(RuiXin.TID, RuiXin.TID+=+id+(!TextUtils.isEmpty(RuiXin.TID=?)?AND(+selection+):), selectionArgs);break;default:throw new IllegalArgumentException(Unknown URI+

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号