自定义ContentProvide

本文介绍如何创建和使用Android的ContentProvider,包括数据存储系统的搭建、ContentProvider类的扩展及实现抽象方法等内容,并提供了一个完整的示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们大家都知道让自己的数据和其它应用程序共享有两种方式:创建自己的Content Provider (即继承自Content Provider的子类) 或者是将自己的数据添加到已有的Content Provider中去,后者需要保证现有的Content Provider和自己的数据类型相同并且具有该 Content Provider的写入的权限。

如果需要创建一个Content Provider,则需要进行的工作主要分为以下3个步骤。

(1) 建立数据的存储系统

数据的存储系统可以由开发人员任意决定,一般来讲,大多数的Content Provider都通过Android的文件存储系统或SQLite 数据库建立自己的数据存储系统。

(2)扩展 ContentProvider类

开发一个继承自ContentProvider类的 子类代码来扩展 ContentProvider类,在这个步骤主要的工作是将要共享的数据包装并以ContentResolver 和 Cursor对象能够访问到的形式对外展示。具体来说需要实现ContentProvider 类中的6个抽象方法。

Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder):将查询的数据以Cursor 对象的形式返回。

Uri insert(Uri uri, ContentValues values):向 Content Provider中插入新数据记录,ContentValues 为数据记录的列名和列值映射。

int update(Uri uri, ContentValues values, String selection, String[] selectionArgs):更新Content Provider中已存在的数据记录。

int delete(Uri uri, String selection, String[] selectionArgs):从Content Provider中删除数据记录。

String getType(Uri uri):返回Content Provider中的数据( MIME )类型。

boolean onCreate():当 Content Provider 启动时被调用。

以上方法将会在ContentResolver 对象中调用,所以很好地实现这些抽象方法会为ContentResolver提供一个完善的外部接口。除了实现抽象方法外,还可以做一些提高可用性的工作。

定义一个 URI 类型的静态常量,命名为CONTENT_URI。 必须为该常量对象定义一个唯一的URI字符串,一般的做法是将 ContentProvider子类的全称类名作为URI字符串,如:
"content://wyf.wpf.MyProvider"。

定义每个字段的列名,如果采用的数据库存储系统为SQLite 数据库,数据表列名可以采用数据库中表的列名。不管数据表中有没有其他的唯一标识一个记录的字段,都应该定义一个"_id"字段 来唯一标识一个记录。模式使用 "INTEGER PRIMARY KEY AUTOINCREMENT" 自动更新 一般将这些列名字符串定义为静态常量, 如"_id"字段名定义为一个名为"_ID" 值为 "_id" 的静态字符串对象。

(3)在应用程序的AdnroidManifest.xml 文件中声明Content Provider组件。

创建好一个Content Provider必须要在应用程序的AndroidManifest.xml 中进行声明,否则该Content Provider对于 Android系统将是不可见的。如果有一个名为MyProvider的类扩展了 ContentProvider类,声明该组件的代码如下:
Xml代码 复制代码 收藏代码
  1. <provider name="wyf.wpf.MyProvider"
  2. authorities="wyf.wpf.myprovider"
  3. ...../> <!-- 为<provider>标记添加name、authorities属性-->

其中name属性为ContentProvider 子类的全称类名,authorities 属性唯一标识了一个ContentProvider。还可以通过 setReadPermission() 和 setWritePermission() 来设置其操作权限。当然也可以再上面的 xml中加入 android:readPermission 或者 android: writePermission属性来控制其权限。

注意:因为ContentProvider可能被不同的进程和线程调用,所以这些方法必须是线程安全的。


下边是一个例子修改了 SDK 中的 Notes例子。首先创建 ContentProvider 的 CONTENT_URI 和 一些字段数据,字段类可以继承自BaseColumns类,它包括了一些基本的字段,比如:_id等 代码如下:

NotePad类
Java代码 复制代码 收藏代码
  1. package xiaohang.zhimeng;
  2. import android.net.Uri;
  3. import android.provider.BaseColumns;
  4. public class NotePad {
  5. //ContentProvider的uri
  6. public static final String AUTHORITY = "com.xh.google.provider.NotePad";
  7. private NotePad(){}
  8. //定义基本字段 实现BaseColumns 这个接口里边已经定义了"_id"字段所以这里不用定义了
  9. public static final class Notes implements BaseColumns{
  10. private Notes(){}
  11. //Uri.parse 方法根据指定字符串创建一个 Uri 对象
  12. public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/notes");
  13. //新的MIME类型-多个
  14. public static final String CONTENT_TYPE = "vnd.android.cursor.dir/vnd.google.note";
  15. //新的MIME类型-单个
  16. public static final String CONTENT_ITME_TYPE = "vnd.android.cursor.item/vnd.google.note";
  17. public static final String DEFAULT_SORT_ORDER = "modified DESC";
  18. //字段
  19. public static final String TITLE = "title";
  20. public static final String NOTE = "note";
  21. public static final String CREATEDDATE = "created";
  22. public static final String MODIFIEDDATE = "modified";
  23. }
  24. }
package xiaohang.zhimeng;

import android.net.Uri;
import android.provider.BaseColumns;

public class NotePad {
	//ContentProvider的uri
	public static final String AUTHORITY = "com.xh.google.provider.NotePad";
	
	private NotePad(){}
	
	//定义基本字段   实现BaseColumns 这个接口里边已经定义了"_id"字段所以这里不用定义了
	public static final class Notes implements BaseColumns{
		private Notes(){}
		   
		//Uri.parse 方法根据指定字符串创建一个 Uri 对象
		public static final Uri		CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/notes");
		
		//新的MIME类型-多个
		public static final String 	CONTENT_TYPE = "vnd.android.cursor.dir/vnd.google.note";
		
		//新的MIME类型-单个
		public static final String 	CONTENT_ITME_TYPE  = "vnd.android.cursor.item/vnd.google.note";
		
		public static final String  DEFAULT_SORT_ORDER = "modified DESC";
		
		//字段
		public static final String  TITLE 			   = "title";
		public static final String  NOTE      		   = "note";
		public static final String  CREATEDDATE 	   = "created";
		public static final String  MODIFIEDDATE 	   = "modified";
	}
}


然后我们需要来创建自己的 ContentProvider 类的 NotePadProvider,它包括了查询、添加、删除、更新等操作以及打开和创建数据库,代码如下:

NotePadProvider 类
Java代码 复制代码 收藏代码
  1. package xiaohang.zhimeng;
  2. import java.util.HashMap;
  3. import xiaohang.zhimeng.NotePad.Notes;
  4. import android.content.ContentProvider;
  5. import android.content.ContentUris;
  6. import android.content.ContentValues;
  7. import android.content.Context;
  8. import android.content.UriMatcher;
  9. import android.content.res.Resources;
  10. import android.database.Cursor;
  11. import android.database.SQLException;
  12. import android.database.sqlite.SQLiteDatabase;
  13. import android.database.sqlite.SQLiteOpenHelper;
  14. import android.database.sqlite.SQLiteQueryBuilder;
  15. import android.net.Uri;
  16. import android.text.TextUtils;
  17. public class NotePadProvider extends ContentProvider{
  18. private static final String TAG = "NotePadProvider";
  19. //数据库名
  20. private static final String DATABASE_NAME = "note_pad.db";
  21. private static final int DATABASE_VERSION = 2;
  22. //表名
  23. private static final String NOTES_TABLE_NAME = "notes";
  24. private static HashMap<String, String> sNotesProjectionMap;
  25. private static final int NOTES = 1;
  26. private static final int NOTE_ID = 2;
  27. private static final UriMatcher sUriMatcher;
  28. private DatabaseHelper mOpenHelper;
  29. //创建表SQL语句
  30. private static final String CREATE_TABLE="CREATE TABLE"
  31. + NOTES_TABLE_NAME
  32. + "(" + Notes._ID
  33. + "INTEGER PRIMARY KEY,"
  34. + Notes.TITLE
  35. + " TEXT,"
  36. + Notes.NOTE
  37. + " TEXT,"
  38. + Notes.CREATEDDATE
  39. + " INTEGER,"
  40. + Notes.MODIFIEDDATE
  41. + " INTEGER" + "); ";
  42. static{
  43. sUriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
  44. sUriMatcher.addURI(NotePad.AUTHORITY, "notes", NOTES);
  45. sUriMatcher.addURI(NotePad.AUTHORITY, "notes/#", NOTE_ID);
  46. sNotesProjectionMap = new HashMap<String, String>();
  47. sNotesProjectionMap.put(Notes._ID, Notes._ID);
  48. sNotesProjectionMap.put(Notes.TITLE, Notes.TITLE);
  49. sNotesProjectionMap.put(Notes.NOTE, Notes.NOTE);
  50. sNotesProjectionMap.put(Notes.CREATEDDATE, Notes.CREATEDDATE);
  51. sNotesProjectionMap.put(Notes.MODIFIEDDATE, Notes.MODIFIEDDATE);
  52. }
  53. private static class DatabaseHelper extends SQLiteOpenHelper{
  54. //构造函数-创建数据库
  55. DatabaseHelper(Context context){
  56. super(context, DATABASE_NAME, null, DATABASE_VERSION);
  57. }
  58. //创建表
  59. @Override
  60. public void onCreate(SQLiteDatabase db) {
  61. db.execSQL(CREATE_TABLE);
  62. }
  63. //更新数据库
  64. @Override
  65. public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
  66. db.execSQL("DROP TABLE IF EXISTS notes");
  67. onCreate(db);
  68. }
  69. }
  70. //删除数据
  71. @Override
  72. public int delete(Uri uri, String selection, String[] selectionArgs) {
  73. SQLiteDatabase db = mOpenHelper.getWritableDatabase();
  74. int count;
  75. switch (sUriMatcher.match(uri)) {
  76. case NOTES:
  77. count = db.delete(NOTES_TABLE_NAME, selection, selectionArgs);
  78. break;
  79. case NOTE_ID:
  80. String noteId = uri.getPathSegments().get(1);
  81. count = db.delete(NOTES_TABLE_NAME, Notes._ID + "=" + noteId + (!TextUtils.isEmpty(selection) ? " AND (" + selection + ')' : ""), selectionArgs);
  82. break;
  83. default:
  84. throw new IllegalArgumentException("Unnown URI" + uri);
  85. }
  86. getContext().getContentResolver().notifyChange(uri, null);
  87. return count;
  88. }
  89. //如果有自定类型,必须实现该方法
  90. @Override
  91. public String getType(Uri uri) {
  92. switch (sUriMatcher.match(uri)) {
  93. case NOTES:
  94. return Notes.CONTENT_TYPE;
  95. case NOTE_ID:
  96. return Notes.CONTENT_ITME_TYPE;
  97. default:
  98. throw new IllegalArgumentException("Unknown URI " + uri);
  99. }
  100. }
  101. //插入数据库
  102. @Override
  103. public Uri insert(Uri uri, ContentValues initialValues) {
  104. if (sUriMatcher.match(uri) != NOTES) {
  105. throw new IllegalArgumentException("Unknown URI " + uri);
  106. }
  107. ContentValues values;
  108. if (initialValues != null) {
  109. values = new ContentValues(initialValues);
  110. }else {
  111. values = new ContentValues();
  112. }
  113. //返回以毫秒为单位的系统当前时间
  114. Long now = Long.valueOf(java.lang.System.currentTimeMillis());
  115. /**
  116. * contaisKey()我的理解就是判断传进来的那个ContentValues有没有相应的列值
  117. * 因为我们的一个ContentValues对象 对应一条数据库的记录
  118. * */
  119. if (values.containsKey(NotePad.Notes.CREATEDDATE) == false) {
  120. values.put(NotePad.Notes.CREATEDDATE, now);
  121. }
  122. if (values.containsKey(NotePad.Notes.MODIFIEDDATE) == false) {
  123. values.put(NotePad.Notes.MODIFIEDDATE, now);
  124. }
  125. if (values.containsKey(NotePad.Notes.TITLE) == false) {
  126. //返回一个全局共享的资源对象
  127. Resources r = Resources.getSystem();
  128. values.put(NotePad.Notes.TITLE, r.getString(android.R.string.unknownName));
  129. }
  130. if (values.containsKey(NotePad.Notes.NOTE) == false) {
  131. values.put(NotePad.Notes.NOTE, "");
  132. }
  133. SQLiteDatabase db = mOpenHelper.getWritableDatabase();
  134. long rowId = db.insert(NOTES_TABLE_NAME, Notes.NOTE, values);
  135. if (rowId > 0) {
  136. Uri noteUri = ContentUris.withAppendedId(NotePad.Notes.CONTENT_URI, rowId);
  137. getContext().getContentResolver().notifyChange(noteUri, null);
  138. return noteUri;
  139. }
  140. throw new SQLException("Failed to insert row into" + uri);
  141. }
  142. //当Content Provider启动时被调用
  143. @Override
  144. public boolean onCreate() {
  145. mOpenHelper = new DatabaseHelper(getContext());
  146. return true;
  147. }
  148. //查询操作 将查询的数据以 Cursor 对象的形式返回
  149. @Override
  150. public Cursor query(Uri uri, String[] projection, String selection,
  151. String[] selectionArgs, String sortOrder) {
  152. SQLiteQueryBuilder qb = new SQLiteQueryBuilder();
  153. switch (sUriMatcher.match(uri)) {
  154. case NOTES:
  155. qb.setTables(NOTES_TABLE_NAME);
  156. qb.setProjectionMap(sNotesProjectionMap);
  157. break;
  158. case NOTE_ID:
  159. qb.setTables(NOTES_TABLE_NAME);
  160. qb.setProjectionMap(sNotesProjectionMap);
  161. qb.appendWhere(Notes._ID + "=" + uri.getPathSegments().get(1));
  162. break;
  163. default:
  164. throw new IllegalArgumentException("Unknown URI " + uri);
  165. }
  166. String orderBy;
  167. //返回true,如果字符串为空或0长度
  168. if (TextUtils.isEmpty(sortOrder)) {
  169. orderBy = NotePad.Notes.DEFAULT_SORT_ORDER;
  170. }else {
  171. orderBy = sortOrder;
  172. }
  173. SQLiteDatabase db = mOpenHelper.getReadableDatabase();
  174. Cursor c = qb.query(db, projection, selection, selectionArgs, null, null, orderBy);
  175. //用来为Cursor对象注册一个观察数据变化的URI
  176. c.setNotificationUri(getContext().getContentResolver(), uri);
  177. return c;
  178. }
  179. //更新数据
  180. @Override
  181. public int update(Uri uri, ContentValues values, String selection,
  182. String[] selectionArgs) {
  183. SQLiteDatabase db = mOpenHelper.getWritableDatabase();
  184. int count;
  185. switch (sUriMatcher.match(uri)) {
  186. case NOTES:
  187. count = db.update(NOTES_TABLE_NAME, values, selection, selectionArgs);
  188. break;
  189. case NOTE_ID:
  190. String noteId = uri.getPathSegments().get(1);
  191. count = db.update(NOTES_TABLE_NAME, values, Notes._ID + "=" + noteId + (!TextUtils.isEmpty(selection) ? " AND (" + selection + ')' : ""), selectionArgs);
  192. break;
  193. default:
  194. throw new IllegalArgumentException("Unknow URI " + uri);
  195. }
  196. return count;
  197. }
  198. }
package xiaohang.zhimeng;

import java.util.HashMap;
import xiaohang.zhimeng.NotePad.Notes;
import android.content.ContentProvider;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.Context;
import android.content.UriMatcher;
import android.content.res.Resources;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteQueryBuilder;
import android.net.Uri;
import android.text.TextUtils;

public class NotePadProvider extends ContentProvider{
	
	private static final String 		   TAG = "NotePadProvider";
	//数据库名
	private static final String 		   DATABASE_NAME = "note_pad.db";
	private static final int 			   DATABASE_VERSION = 2;
	//表名
	private static final String 		   NOTES_TABLE_NAME = "notes";
	private static HashMap<String, String> sNotesProjectionMap;
	private static final int 			   NOTES = 1;
	private static final int 			   NOTE_ID = 2;
	private static final UriMatcher		   sUriMatcher;
	private DatabaseHelper mOpenHelper;
	//创建表SQL语句
	private static final String 		   CREATE_TABLE="CREATE TABLE"
														+ NOTES_TABLE_NAME
														+ "(" + Notes._ID
														+ "INTEGER PRIMARY KEY,"
														+ Notes.TITLE
														+ " TEXT,"
														+ Notes.NOTE
														+ " TEXT,"
														+ Notes.CREATEDDATE
														+ " INTEGER,"
														+ Notes.MODIFIEDDATE
														+ " INTEGER" + "); ";
	
	static{
		sUriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
		sUriMatcher.addURI(NotePad.AUTHORITY, "notes", NOTES);
		sUriMatcher.addURI(NotePad.AUTHORITY, "notes/#", NOTE_ID);
		
		sNotesProjectionMap = new HashMap<String, String>();
		sNotesProjectionMap.put(Notes._ID, Notes._ID);
		sNotesProjectionMap.put(Notes.TITLE, Notes.TITLE);
		sNotesProjectionMap.put(Notes.NOTE, Notes.NOTE);
		sNotesProjectionMap.put(Notes.CREATEDDATE, Notes.CREATEDDATE);
		sNotesProjectionMap.put(Notes.MODIFIEDDATE, Notes.MODIFIEDDATE);

	}
	
	private static class DatabaseHelper extends SQLiteOpenHelper{
		//构造函数-创建数据库
		DatabaseHelper(Context context){
			super(context, DATABASE_NAME, null, DATABASE_VERSION);
		}
		
		//创建表
		@Override
		public void onCreate(SQLiteDatabase db) {
			db.execSQL(CREATE_TABLE);
		}
		
		//更新数据库
		@Override
		public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
			db.execSQL("DROP TABLE IF EXISTS notes");
			onCreate(db);
		}
	}

	//删除数据
	@Override
	public int delete(Uri uri, String selection, String[] selectionArgs) {
		SQLiteDatabase db = mOpenHelper.getWritableDatabase();
		int count;
		switch (sUriMatcher.match(uri)) {
		case NOTES:
			count = db.delete(NOTES_TABLE_NAME, selection, selectionArgs);
			break;
			
		case NOTE_ID:
			String noteId = uri.getPathSegments().get(1);
			count = db.delete(NOTES_TABLE_NAME, Notes._ID + "=" + noteId + (!TextUtils.isEmpty(selection) ? " AND (" + selection + ')' : ""), selectionArgs);
			break;
			
		default:
			throw new IllegalArgumentException("Unnown URI" + uri);
		}
		getContext().getContentResolver().notifyChange(uri, null);
		return count;
	}
	//如果有自定类型,必须实现该方法
	@Override
	public String getType(Uri uri) {
		switch (sUriMatcher.match(uri)) {
		case NOTES:
			return Notes.CONTENT_TYPE;

		case NOTE_ID:
			return Notes.CONTENT_ITME_TYPE;
			
		default:
			throw new IllegalArgumentException("Unknown URI " + uri);
		}
	}

	//插入数据库
	@Override
	public Uri insert(Uri uri, ContentValues initialValues) {
		if (sUriMatcher.match(uri) != NOTES) {
			throw new IllegalArgumentException("Unknown URI " + uri);
		}
		ContentValues values;
		if (initialValues != null) {
			values = new ContentValues(initialValues);
		}else {
			values = new ContentValues();
		}
		//返回以毫秒为单位的系统当前时间
		Long now = Long.valueOf(java.lang.System.currentTimeMillis());
		/**
		 * contaisKey()我的理解就是判断传进来的那个ContentValues有没有相应的列值
		 * 因为我们的一个ContentValues对象 对应一条数据库的记录
		 * */
		if (values.containsKey(NotePad.Notes.CREATEDDATE) == false) {
			values.put(NotePad.Notes.CREATEDDATE, now);
		}
		if (values.containsKey(NotePad.Notes.MODIFIEDDATE) == false) {
			values.put(NotePad.Notes.MODIFIEDDATE, now);
		}
		if (values.containsKey(NotePad.Notes.TITLE) == false) {
			//返回一个全局共享的资源对象
			Resources r = Resources.getSystem();
			values.put(NotePad.Notes.TITLE, r.getString(android.R.string.unknownName));
		}
		if (values.containsKey(NotePad.Notes.NOTE) == false) {
			values.put(NotePad.Notes.NOTE, "");
		}
		SQLiteDatabase db = mOpenHelper.getWritableDatabase();
		long rowId = db.insert(NOTES_TABLE_NAME, Notes.NOTE, values);
		if (rowId > 0) {
			Uri noteUri = ContentUris.withAppendedId(NotePad.Notes.CONTENT_URI, rowId);
			getContext().getContentResolver().notifyChange(noteUri, null);
			return noteUri;
		}
		throw new SQLException("Failed to insert row into" + uri);
	}
	
	//当Content Provider启动时被调用
	@Override
	public boolean onCreate() {
		mOpenHelper = new DatabaseHelper(getContext());
		return true;
	}
	
	//查询操作  将查询的数据以 Cursor 对象的形式返回
	@Override
	public Cursor query(Uri uri, String[] projection, String selection,
			String[] selectionArgs, String sortOrder) {
		SQLiteQueryBuilder qb = new SQLiteQueryBuilder();
		switch (sUriMatcher.match(uri)) {
		case NOTES:
			qb.setTables(NOTES_TABLE_NAME);
			qb.setProjectionMap(sNotesProjectionMap);
			break;
			
		case NOTE_ID:
			qb.setTables(NOTES_TABLE_NAME);
			qb.setProjectionMap(sNotesProjectionMap);
			qb.appendWhere(Notes._ID + "=" + uri.getPathSegments().get(1));
			break;
			
		default:
			throw new IllegalArgumentException("Unknown URI " + uri);
		}
		String orderBy;
		//返回true,如果字符串为空或0长度
		if (TextUtils.isEmpty(sortOrder)) {
			orderBy = NotePad.Notes.DEFAULT_SORT_ORDER;
		}else {
			orderBy = sortOrder;
		}
		SQLiteDatabase db = mOpenHelper.getReadableDatabase();
		Cursor c = qb.query(db, projection, selection, selectionArgs, null, null, orderBy);
		//用来为Cursor对象注册一个观察数据变化的URI
		c.setNotificationUri(getContext().getContentResolver(), uri);
		return c;
	}

	//更新数据
	@Override
	public int update(Uri uri, ContentValues values, String selection,
			String[] selectionArgs) {
		SQLiteDatabase db = mOpenHelper.getWritableDatabase();
		int count;
		switch (sUriMatcher.match(uri)) {
		case NOTES:
			count = db.update(NOTES_TABLE_NAME, values, selection, selectionArgs);
			break;
		
		case NOTE_ID:
			String noteId = uri.getPathSegments().get(1);
			count = db.update(NOTES_TABLE_NAME, values, Notes._ID + "=" + noteId + (!TextUtils.isEmpty(selection) ? " AND (" + selection + ')' : ""), selectionArgs);
			break;
			
		default:
			throw new IllegalArgumentException("Unknow URI " + uri);
		}
		
		return count;
	}
}


下面我们要来创建一个Activity类,首先向其中插入两个数据,然后通过Toast来显示数据库中的数据。 运行效果如下:





代码 Activity01 类
Java代码 复制代码 收藏代码
  1. package xiaohang.zhimeng;
  2. import android.app.Activity;
  3. import android.content.ContentValues;
  4. import android.database.Cursor;
  5. import android.net.Uri;
  6. import android.os.Bundle;
  7. import android.view.Gravity;
  8. import android.widget.Toast;
  9. public class Activity01 extends Activity {
  10. @Override
  11. public void onCreate(Bundle savedInstanceState) {
  12. super.onCreate(savedInstanceState);
  13. setContentView(R.layout.main);
  14. /*插入数据*/
  15. ContentValues values = new ContentValues();
  16. values.put(NotePad.Notes.TITLE, "title1");
  17. values.put(NotePad.Notes.NOTE, "NOTENOTE1");
  18. getContentResolver().insert(NotePad.Notes.CONTENT_URI, values);
  19. values.clear();
  20. values.put(NotePad.Notes.TITLE, "title2");
  21. values.put(NotePad.Notes.NOTE, "NOTENOTE2");
  22. getContentResolver().insert(NotePad.Notes.CONTENT_URI, values);
  23. //显示
  24. displayNote();
  25. }
  26. private void displayNote(){
  27. String columns[] = new String[] { NotePad.Notes._ID,
  28. NotePad.Notes.TITLE,
  29. NotePad.Notes.NOTE,
  30. NotePad.Notes.CREATEDDATE,
  31. NotePad.Notes.MODIFIEDDATE};
  32. Uri myUri = NotePad.Notes.CONTENT_URI;
  33. Cursor cur = managedQuery(myUri, columns, null, null, null);
  34. if (cur.moveToFirst()) {
  35. String id = null;
  36. String titile = null;
  37. do {
  38. id = cur.getString(cur.getColumnIndex(NotePad.Notes._ID));
  39. titile = cur.getString(cur.getColumnIndex(NotePad.Notes.TITLE));
  40. Toast toast = Toast.makeText(this, "TITILE:"+id + "\t" + "NOTE:" + titile, Toast.LENGTH_LONG);
  41. toast.setGravity(Gravity.TOP|Gravity.CENTER, 0, 40);
  42. toast.show();
  43. } while (cur.moveToNext());
  44. }
  45. }
  46. }
package xiaohang.zhimeng;

import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.view.Gravity;
import android.widget.Toast;

public class Activity01 extends Activity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        /*插入数据*/
        ContentValues values = new ContentValues();
        values.put(NotePad.Notes.TITLE, "title1");
        values.put(NotePad.Notes.NOTE, "NOTENOTE1");
        getContentResolver().insert(NotePad.Notes.CONTENT_URI, values);
        
        values.clear();
        values.put(NotePad.Notes.TITLE, "title2");
        values.put(NotePad.Notes.NOTE, "NOTENOTE2");
        getContentResolver().insert(NotePad.Notes.CONTENT_URI, values);
        //显示
        displayNote();
    }
    
    private void displayNote(){
    	String columns[] = new String[] { NotePad.Notes._ID,
    									  NotePad.Notes.TITLE,
    									  NotePad.Notes.NOTE,
    									  NotePad.Notes.CREATEDDATE,
    									  NotePad.Notes.MODIFIEDDATE};
    	
    	Uri myUri = NotePad.Notes.CONTENT_URI;
    	Cursor cur = managedQuery(myUri, columns, null, null, null);
    	if (cur.moveToFirst()) {
			String id = null;
			String titile = null;
			do {
				id = cur.getString(cur.getColumnIndex(NotePad.Notes._ID));
				titile = cur.getString(cur.getColumnIndex(NotePad.Notes.TITLE));
				Toast toast = Toast.makeText(this, "TITILE:"+id + "\t" + "NOTE:" + titile, Toast.LENGTH_LONG);
				toast.setGravity(Gravity.TOP|Gravity.CENTER, 0, 40);
				toast.show();
			} while (cur.moveToNext());
		}
    }
}


最后不要忘记在AndroidManifest.xml文件中声明我们使用的ContentProvider,下面是我的
AndroidManifest.xml文件
Xml代码 复制代码 收藏代码
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"
  3. package="xiaohang.zhimeng" android:versionCode="1"
  4. android:versionName="1.0">
  5. <application android:icon="@drawable/icon"
  6. android:label="@string/app_name">
  7. <provider android:name="NotePadProvider"
  8. android:authorities="com.xh.google.provider.NotePad" />
  9. <activity android:name=".Activity01"
  10. android:label="@string/app_name">
  11. <intent-filter>
  12. <action android:name="android.intent.action.MAIN" />
  13. <category
  14. android:name="android.intent.category.LAUNCHER" />
  15. </intent-filter>
  16. <intent-filter>
  17. <data
  18. android:mimeType="vnd.android.cursor.dir/vnd.google.note" />
  19. </intent-filter>
  20. <intent-filter>
  21. <data
  22. android:mimeType="vnd.android.cursor.item/vnd.google.note" />
  23. </intent-filter>
  24. </activity>
  25. </application>
  26. <uses-sdk android:minSdkVersion="5" />
  27. </manifest>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值