Android四大组件之ContentProvider

         以前用ContentResolver只是读取一下手机里的数据,现在公司做的东西也用不到提供给别人数据,今天主席提醒才想起来,我还跟这个传说中的四大组件之一不是很熟,今天就来研究一下它。

        1.ContentProvider简介

        当应用继承ContentProvider类,并重写该类用于提供数据和存储数据的方法,就可以向其他应用共享其数据。虽然使用其他方法也可以对外共享数据,但数据访问方式会因数据存储的方式而不同,如:采用文件方式对外共享数据,需要进行文件操作读写数据;采用sharedpreferences共享数据,需要使用sharedpreferences API读写数据。而使用ContentProvider共享数据的好处是统一了数据访问方式。

        2.ContentProvider应用场景

        (1)存储和读取数据

        (2)实现数据共享

      下面通过一个demo分享一下数据,供其他app操作(这里只实现了查询)

/**
 * 
 */
package com.zimo.datebase;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

/**
 * @author 子墨
 *
 * 2015-3-4下午3:10:16
 */
public class MyDatabaseHelper extends SQLiteOpenHelper {

	public MyDatabaseHelper(Context context, String name,
			CursorFactory factory, int version) {
		super(context, name, factory, version);
	}

	/* (non-Javadoc)
	 * @see android.database.sqlite.SQLiteOpenHelper#onCreate(android.database.sqlite.SQLiteDatabase)
	 */
	@Override
	public void onCreate(SQLiteDatabase db) {
		/**
		 * 創建student表
		 */
		db.execSQL("create table student("+"id integer primary key autoincrement,"+"name text,"+"number integer,"+"sex text)");
	}

	/* (non-Javadoc)
	 * @see android.database.sqlite.SQLiteOpenHelper#onUpgrade(android.database.sqlite.SQLiteDatabase, int, int)
	 */
	@Override
	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
		/**
		 * 刪除表并重建
		 */
		db.execSQL("drop table if exists student");
		onCreate(db);
	}

}



以上代码使用SQLite存储数据,建了一张表(student)

package com.zimo.datebase;

import android.os.Bundle;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class MainActivity extends Activity implements OnClickListener {
	
	MyDatabaseHelper helper;
	SQLiteDatabase db;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		Button button=(Button) findViewById(R.id.button1);
		button.setOnClickListener(this);
		
		helper=new MyDatabaseHelper(getApplicationContext(), "student.db", null, 1);
		
		db=helper.getWritableDatabase();
		
		ContentValues contentValues=new ContentValues();
		
		contentValues.put("name", "zimo");
		contentValues.put("number", 111);
		contentValues.put("sex", "f");
		
		db.insert("student",null,contentValues);
		
		contentValues.put("name", "thea");
		contentValues.put("number", 112);
		contentValues.put("sex", "f");
		
		db.insert("student",null,contentValues);
	}

	@Override
	public void onClick(View v) {
		Cursor cursor = db.query("student", null, null, null, null, null, null);
		if (!cursor.moveToFirst()) {
			return;
		}else {
			while (cursor.moveToNext()) {
				String name=cursor.getString(cursor.getColumnIndex("name"));
				int number=cursor.getInt(cursor.getColumnIndex("number"));
				String sex=cursor.getString(cursor.getColumnIndex("sex"));
				
				Log.d("com.zimo.datebase", "姓名:"+name+"學號:"+number+"性別:"+sex);
			}
		}
	}

}



代码贴到这应该都是你熟悉的,就是创建一个数据库(student.db),然后创建了一张表(student),然后在表中插入数据,这里问了确保我的数据已经插入,我又取出来看了看,这一段比较多余,可以忽略

        下面就开始共享数据,我个人理解,就是提供个接口(uri)供别人访问,也没有多复杂,下面开始实现,要是提供ContentProvider功能,就要实现ContentProvider这个抽象方法

/**
 * 
 */
package com.zimo.datebase;

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

/**
 * @author 子墨
 *
 * 2015-3-4下午3:25:26
 */
public class MyProvider extends ContentProvider {
	
	private MyDatabaseHelper helper;

	/* (non-Javadoc)
	 * @see android.content.ContentProvider#onCreate()
	 */
	@Override
	public boolean onCreate() {
		helper=new MyDatabaseHelper(getContext(), "student.db", null, 1);
		return true;
	}

	/* (non-Javadoc)
	 * @see android.content.ContentProvider#query(android.net.Uri, java.lang.String[], java.lang.String, java.lang.String[], java.lang.String)
	 */
	@Override
	public Cursor query(Uri uri, String[] projection, String selection,
			String[] selectionArgs, String sortOrder) {
		SQLiteDatabase db=helper.getReadableDatabase();
		
		Cursor cursor=db.query("student", projection, selection, selectionArgs, null, null, sortOrder);
		return cursor;
	}

	/* (non-Javadoc)
	 * @see android.content.ContentProvider#getType(android.net.Uri)
	 */
	@Override
	public String getType(Uri uri) {
		// TODO Auto-generated method stub
		return null;
	}

	/* (non-Javadoc)
	 * @see android.content.ContentProvider#insert(android.net.Uri, android.content.ContentValues)
	 */
	@Override
	public Uri insert(Uri uri, ContentValues values) {
		return null;
	}

	/* (non-Javadoc)
	 * @see android.content.ContentProvider#delete(android.net.Uri, java.lang.String, java.lang.String[])
	 */
	@Override
	public int delete(Uri uri, String selection, String[] selectionArgs) {
		return 0;
	}

	/* (non-Javadoc)
	 * @see android.content.ContentProvider#update(android.net.Uri, android.content.ContentValues, java.lang.String, java.lang.String[])
	 */
	@Override
	public int update(Uri uri, ContentValues values, String selection,
			String[] selectionArgs) {
		return 0;
	}

}


这里的数据分享之提供了查询功能,要是提供其他的功能,你对应的就实现对应的方法,这样还没完,还需要提供个访问接口


<provider android:name=".MyProvider"
            android:authorities="com.zimo.datebase.MyProvider">
        </provider>

ok了,你通过content://com.zimo.datebase.MyProvider/student这几接口,就能访问到这个app的数据了.


下面是测试的部分:

package com.zimo.getdata;

import android.net.Uri;
import android.os.Bundle;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.content.ContentResolver;
import android.database.Cursor;
import android.util.Log;
import android.view.Menu;

public class MainActivity extends Activity {

	@SuppressLint("NewApi")
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		ContentResolver resolver=this.getContentResolver();
		Uri uri=Uri.parse("content://com.zimo.datebase.MyProvider/student");
		Cursor cursor=resolver.query(uri, null, null, null, null, null);
		
		if (!cursor.moveToFirst()) {
			return;
		}else {
			while (cursor.moveToNext()) {
				String name=cursor.getString(cursor.getColumnIndex("name"));
				int number=cursor.getInt(cursor.getColumnIndex("number"));
				String sex=cursor.getString(cursor.getColumnIndex("sex"));
				
				Log.d("com.zimo.getdata", "姓名:"+name+"學號:"+number+"性別:"+sex);
			}
		}
	}

}


代码下载地址:http://download.csdn.net/detail/elinavampire/8472781

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值