本人原创作品,谢绝转载!
作为android四大组件之一,今天总结一下它的用法。
ContentProvider官方有很多地方提到,其中一个是在API文档上(http://developer.android.com/guide/topics/providers/content-providers.html)面有介绍,有兴趣去看一下,虽然是英文的,对了解ContentProvider很有用;还有一个地方是android SDK中的%android_home%/samples/android-x/下面的一个NotePad的demo,代码架构可以参考该demo。本文来自此demo,并做相关修改。
代码:
SQLite数据库直接操作类:
DatabaseHelper.java
package com.jacp.database;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import com.jacp.demo.provider.Provider;
/**
* 操作数据库
* @author jacp
*
*/
public class DatabaseHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "jacp_demo.db";
private static final int DATABASE_VERSION = 1;
public DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("CREATE TABLE " + Provider.PersonColumns.TABLE_NAME + " ("
+ Provider.PersonColumns._ID + " INTEGER PRIMARY KEY,"
+ Provider.PersonColumns.NAME + " TEXT,"
+ Provider.PersonColumns.AGE + " INTEGER"
+ ");");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS " + Provider.PersonColumns.TABLE_NAME);
onCreate(db);
}
}
保存跟数据库及表有关的常量:
Provider.java
package com.jacp.demo.provider;
import android.net.Uri;
import android.provider.BaseColumns;
/**
* 存放跟数据库有关的常量
* @author jacp
*
*/
public class Provider {
// 这个是每个Provider的标识,在Manifest中使用
public static final String AUTHORITY = "com.jacp.provider.demo.person";
public static final String CONTENT_TYPE = "vnd.android.cursor.dir/vnd.jacp.demo";
public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/vnd.jacp.demo";
/**
* 跟Person表相关的常量
* @author jacp
*
*/
public static final class PersonColumns implements BaseColumns {
// CONTENT_URI跟数据库的表关联,最后根据CONTENT_URI来查询对应的表
public static final Uri CONTENT_URI = Uri.parse("content://"+ AUTHORITY +