Android开发入门之采用ContentProvider对外共享数据

在cn.leigo,db下新建PersonProvider类,该类集成ContentProvider:

package cn.leigo.db;

import android.content.ContentProvider;
import android.content.ContentValues;
import android.database.Cursor;
import android.net.Uri;

public class PersonProvider extends ContentProvider {

	@Override
	public boolean onCreate() {
		// TODO Auto-generated method stub
		return false;
	}

	@Override
	public Cursor query(Uri uri, String[] projection, String selection,
			String[] selectionArgs, String sortOrder) {
		// TODO Auto-generated method stub
		return null;
	}

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

	@Override
	public Uri insert(Uri uri, ContentValues values) {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public int delete(Uri uri, String selection, String[] selectionArgs) {
		// TODO Auto-generated method stub
		return 0;
	}

	@Override
	public int update(Uri uri, ContentValues values, String selection,
			String[] selectionArgs) {
		// TODO Auto-generated method stub
		return 0;
	}

}

并在AndroidManifest,xml文件中进行配置

 <provider android:name="cn.leigo.db.PersonProvider" android:authorities="cn.leigo.providers.personprovider"/>

对外提供查询方法:

package cn.leigo.db;

import cn.leigo.service.DBOpenHelper;
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 PersonProvider extends ContentProvider {
	private DBOpenHelper dbOpenHelper;
	private static final UriMatcher MATCHER = new UriMatcher(
			UriMatcher.NO_MATCH);
	private static final int PERSONS = 1;
	static {
		MATCHER.addURI("cn.leigo.providers.personprovider", "person", PERSONS);
	}

	@Override
	public boolean onCreate() {
		dbOpenHelper = new DBOpenHelper(getContext());
		return true;
	}

	@Override
	public Cursor query(Uri uri, String[] projection, String selection,
			String[] selectionArgs, String sortOrder) {
		return null;
	}

	@Override
	public String getType(Uri uri) {
		return null;
	}

	@Override
	public Uri insert(Uri uri, ContentValues values) {
		SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
		switch (MATCHER.match(uri)) {
		case PERSONS:
			long rowid = db.insert("person", "name", values); // 主键值
			// content://cn.leigo.providers.personprovider/person/10
			// Uri insertUri =
			// Uri.parse("content://cn.leigo.providers.personprovider/person/"+
			// rowid);
			Uri insertUri = ContentUris.withAppendedId(uri, rowid);
			return insertUri;
		default:
			throw new IllegalArgumentException("this is Unknow Uri:" + uri);
		}
	}

	@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;
	}

}

然后进行测试,新建一个测试项目other,所要测试的工程为db

package cn.leigo.db.test;

import android.content.ContentResolver;
import android.content.ContentValues;
import android.net.Uri;
import android.test.AndroidTestCase;

public class AccessContentProviderTest extends AndroidTestCase {

	public void testInsert() throws Exception {
		Uri uri = Uri
				.parse("content://cn.leigo.providers.personprovider/person");
		ContentResolver resolver = getContext().getContentResolver();
		ContentValues values = new ContentValues();
		values.put("name", "zhaoliu");
		values.put("phone", "18832358032");
		values.put("amount", 10000);
		resolver.insert(uri, values);
	}
}

可以看到数据已经插入进去了。


对外提供删除方法:

    private static final int PERSON = 2;
    static {
        MATCHER.addURI("cn.leigo.providers.personprovider", "person", PERSONS);
        MATCHER.addURI("cn.leigo.providers.personprovider", "person/#", PERSON);
    }
    @Override
    public int delete(Uri uri, String selection, String[] selectionArgs) {
        SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
        int num = 0;
        switch (MATCHER.match(uri)) {
        case PERSONS:
            num = db.delete("person", selection, selectionArgs);
            break;
        case PERSON:
            long rowid = ContentUris.parseId(uri);
            String where = "personid=" + rowid;
            if (!TextUtils.isEmpty(selection)) {
                where += " and " + selection;
            }
            num = db.delete("person", where, selectionArgs);
            break;
        default:
            throw new IllegalArgumentException("this is Unknow Uri:" + uri);
        }
        return num;
    }

 测试类: 

    public void testDelete() throws Exception {
        Uri uri = Uri
                .parse("content://cn.leigo.providers.personprovider/person/20");
        ContentResolver resolver = getContext().getContentResolver();
        resolver.delete(uri, null, null);
    }

运行后:

id为20的数据已删除。


对外提供更新方法:

        @Override
	public int update(Uri uri, ContentValues values, String selection,
			String[] selectionArgs) {
		SQLiteDatabase db = dbOpenHelper.getWritableDatabase();
		int num = 0;
		switch (MATCHER.match(uri)) {
		case PERSONS:
			num = db.update("person", values, selection, selectionArgs);
			break;
		case PERSON:
			long rowid = ContentUris.parseId(uri);
			String where = "personid=" + rowid;
			if (!TextUtils.isEmpty(selection)) {
				where += " and " + selection;
			}
			num = db.update("person", values, where, selectionArgs);
			break;
		default:
			throw new IllegalArgumentException("this is Unknow Uri:" + uri);
		}
		return num;
	}

测试类:

    public void testUpdate() throws Exception {
        Uri uri = Uri
                .parse("content://cn.leigo.providers.personprovider/person/19");
        ContentResolver resolver = getContext().getContentResolver();
        ContentValues values = new ContentValues();
        values.put("name", "wangwu");
        resolver.update(uri, values, null, null);
    }

运行后:

id为19的Person name已改为wangwu



对外提供查询方法:

	@Override
	public Cursor query(Uri uri, String[] projection, String selection,
			String[] selectionArgs, String sortOrder) {
		Cursor cursor = null;
		SQLiteDatabase db = dbOpenHelper.getReadableDatabase();
		switch (MATCHER.match(uri)) {
		case PERSONS:
			cursor = db.query("person", null, selection, selectionArgs, null,
					null, sortOrder);
			break;
		case PERSON:
			long rowid = ContentUris.parseId(uri);
			String where = "personid=" + rowid;
			if (!TextUtils.isEmpty(selection)) {
				where += " and " + selection;
			}
			cursor = db.query("person", projection, where, selectionArgs,
					null, null, sortOrder);
			break;
		default:
			throw new IllegalArgumentException("this is Unknow Uri:" + uri);
		}
		return cursor;
	}


测试类:

	public void testQuery() throws Exception {
		Uri uri = Uri
				.parse("content://cn.leigo.providers.personprovider/person");
		ContentResolver resolver = getContext().getContentResolver();
		Cursor cursor = resolver.query(uri, null, null, null, null);
		while (cursor.moveToNext()) {
			String name = cursor.getString(cursor.getColumnIndex("name"));
			Log.i(TAG, name);
		}
		cursor.close();
	}


	@Override
	public String getType(Uri uri) {
		String type = "";
		switch (MATCHER.match(uri)) {
		case PERSONS:
			type = "vnd.android.cursor.dir/person";
			break;
		case PERSON:
			type = "vnd.android.cursor.item/person";
			break;
		default:
			throw new IllegalArgumentException("this is Unknow Uri:" + uri);
		}
		return type;
	}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值