Android学习——content provider

百度:

Content Provider,即内容提供商或者内容提供器。

Android中的Content provider机制可支持在多个应用中存储和读取数据。这也是跨应用共享数据的方式之一,还有文件,sharePreference,SQLite数据库等方式存储共享数据库,但是ContentProvider更好的提供了数据共享接口的统一性。在android系统中,没有一个公共的内存区域,供多个应用共享存储数据。

Android提供了一些主要数据类型的Content provider,比如音频、视频、图片和私人通讯录等。可在android.provider包下面找到一些android提供的Content provider。可以获得这些Content provider,查询它们包含的数据,当然前提是已获得适当的读取权限。


基本语法:

Uri类:

Uri代表了要操作的数据,Uri主要包含了两部分信息:1.需要操作的ContentProvider ,2.对ContentProvider中的什么数据进行操作,一个Uri由以下几部分组成:

       1.scheme:ContentProvider(内容提供者)的scheme已经由Android所规定为:content://。
       2.主机名(或Authority):用于唯一标识这个ContentProvider,外部调用者可以根据这个标识来找到它。
       3.路径(path):可以用来表示我们要操作的数据,路径的构建应根据业务而定,如下:
•         要操作contact表中id为10的记录,可以构建这样的路径:/contact/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/contact")

public static final String AUTHORITY = "small_notes";
public static final Uri CONTENT_NOTE_URI = Uri.parse("content://" + AUTHORITY + "/note");
Uri uri = context.getContentResolver().insert(Notes.CONTENT_NOTE_URI, values);//插入操作


继承自ContentProvider的类

private static final UriMatcher mMatcher;

1.首先把你需要匹配Uri路径全部给注册上,如下:
       //常量UriMatcher.NO_MATCH表示不匹配任何路径的返回码(-1)。
       UriMatcher  uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
     

 static {
		mMatcher = new UriMatcher(UriMatcher.NO_MATCH);
		mMatcher.addURI(Notes.AUTHORITY, "note", URI_NOTE);
		mMatcher.addURI(Notes.AUTHORITY, "note/#", URI_NOTE_ITEM);
		mMatcher.addURI(Notes.AUTHORITY, "data", URI_DATA);
		mMatcher.addURI(Notes.AUTHORITY, "data/#", URI_DATA_ITEM);
	}

2.ContentUris:用于获取Uri路径后面的ID部分,它有两个比较实用的方法:
•         withAppendedId(uri, id)用于为路径加上ID部分
•         parseId(uri)方法用于从路径中获取ID部分

•         uri.getPathSegments().get(1)


实例代码:

package edu.cslg.notes.data;

import edu.cslg.notes.data.Notes.NoteColumns;
import edu.cslg.notes.data.NotesDatabaseHelper.TABLE;
import android.content.ContentProvider;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;

public class NotesProvider extends ContentProvider {

	private static final UriMatcher mMatcher;

	private NotesDatabaseHelper mHelper;

	private static final String TAG = "NotesProvider";

	private static final int URI_NOTE = 1;
	private static final int URI_NOTE_ITEM = 2;
	private static final int URI_DATA = 3;
	private static final int URI_DATA_ITEM = 4;

	static {
		mMatcher = new UriMatcher(UriMatcher.NO_MATCH);
		mMatcher.addURI(Notes.AUTHORITY, "note", URI_NOTE);
		mMatcher.addURI(Notes.AUTHORITY, "note/#", URI_NOTE_ITEM);
		mMatcher.addURI(Notes.AUTHORITY, "data", URI_DATA);
		mMatcher.addURI(Notes.AUTHORITY, "data/#", URI_DATA_ITEM);

	}

	@Override
	public boolean onCreate() {
		mHelper = NotesDatabaseHelper.getInstance(getContext());
		return false;
	}

	@Override
	public Cursor query(Uri uri, String[] projection, String selection,
			String[] selectionArgs, String sortOrder) {
		SQLiteDatabase db = mHelper.getReadableDatabase();
		Cursor cursor = null;
		switch (mMatcher.match(uri)) {
		case URI_NOTE:
			cursor = db.query(TABLE.NOTE, projection, selection, selectionArgs,
					null, null, sortOrder);
			break;
		case URI_NOTE_ITEM:
			selection = NoteColumns.ID + "=?";
			selectionArgs = new String[] { uri.getPathSegments().get(1) };
			cursor = db.query(TABLE.NOTE, projection, selection, selectionArgs,
					null, null, null);
			break;

		case URI_DATA:
			cursor = db.query(TABLE.DATA, projection, selection, selectionArgs,
					null, null, null);
			break;
		default:
			break;
		}

		return cursor;
	}

	@Override
	public String getType(Uri uri) {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public Uri insert(Uri uri, ContentValues values) {
		SQLiteDatabase db = mHelper.getWritableDatabase();
		long noteId = 0;
		switch (mMatcher.match(uri)) {
		case URI_NOTE:
			noteId = db.insert(TABLE.NOTE, null, values);
			break;
		case URI_DATA:
			noteId = db.insert(TABLE.DATA, null, values);
		default:
			break;
		}
		return ContentUris.withAppendedId(uri, noteId);
	}

	@Override
	public int delete(Uri uri, String selection, String[] selectionArgs) {
		SQLiteDatabase db = mHelper.getWritableDatabase();
		long noteId = 0;
		switch (mMatcher.match(uri)) {
		case URI_NOTE:
			db.delete(TABLE.NOTE, selection, selectionArgs);
		}
		return 0;
	}

	@Override
	public int update(Uri uri, ContentValues values, String selection,
			String[] selectionArgs) {
		SQLiteDatabase db = mHelper.getWritableDatabase();
		switch (mMatcher.match(uri)) {
		case URI_DATA_ITEM:
			db.update(TABLE.DATA, values, selection, selectionArgs);
			break;
		case URI_NOTE_ITEM:
			String id = uri.getPathSegments().get(1);
			db.update(TABLE.NOTE, values, NoteColumns.ID + "=?",
					new String[] { id });
		default:
			break;
		}
		return 0;
	}

}







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值