這個例子是結合在前面寫的sqlite數據庫地址在這裏加上ContentProvider,使別的應用程序可以訪問它的數據,使用ContentProvider需要繼承ContentProvider,然後重寫六個方法
onCreate()
初始化內容提供器的時候調用。通常會在這裏完成對數據庫的創建和升級等操作,返回 true 表示內容提供器初始化成功,返回 false 則表示失敗。注意,只有當存在ContentResolver 嘗試訪問我們程序中的數據時,內容提供器纔會被初始化。query()
從內容提供器中查詢數據。使用 uri 參數來確定查詢哪張表,projection 參數用於確定查詢哪些列,selection 和 selectionArgs 參數用於約束查詢哪些行,sortOrder 參數用於對結果進行排序,查詢的結果存放在 Cursor 對象中返回。insert()
向內容提供器中添加一條數據。使用 uri 參數來確定要添加到的表,待添加的數據保存在 values 參數中。添加完成後,返回一個用於表示這條新記錄的 URI。update()
更新內容提供器中已有的數據。使用 uri 參數來確定更新哪一張表中的數據,新數據保存在 values 參數中,selection 和 selectionArgs 參數用於約束更新哪些行,受影響的行數將作爲返回值返回。delete()
從內容提供器中刪除數據。使用 uri 參數來確定刪除哪一張表中的數據,selection和 selectionArgs 參數用於約束刪除哪些行,被刪除的行數將作爲返回值返回。- getType()
根據傳入的內容 URI 來返回相應的 MIME 類型。
一個標準的內容 URI 寫法是這樣的:
content://com.example.app.provider/table1,這就表示調用方期望訪問的是 com.example.app 這個應用的 table1 表中的數據。
我們還可以在這個內容 URI 的後面加上一個 id:
content://com.example.app.provider/table1/1,這就表示調用方期望訪問的是 com.example.app 這個應用的 table1 表中 id 爲 1 的數據。
內容 URI 的格式主要就只有以上兩種,以路徑結尾就表示期望訪問該表中所有的數據,以 id 結尾就表示期望訪問該表中擁有相應 id 的數據。
我們可以使用通配符的方式來分別匹配這兩種格式的內容 URI,規則如下。
1. *:表示匹配任意長度的任意字符
2. #:表示匹配任意長度的數字
所以,一個能夠匹配任意表的內容 URI 格式就可以寫成:
content://com.example.app.provider/*
而一個能夠匹配 table1 表中任意一行數據的內容 URI 格式就可以寫成:
content://com.example.app.provider/table1/#
接着, 我們再借助UriMatcher這個類就可以輕鬆地實現匹配內容URI的功能。 UriMatcher中提供了一個 addURI()方法,這個方法接收三個參數,可以分別把權限、路徑和一個自定義代碼傳進去。這樣,當調用 UriMatcher 的 match()方法時,就可以將一個 Uri 對象傳入,返回值是某個能夠匹配這個 Uri 對象所對應的自定義代碼
getType的寫法
它是所有的內容提供器都必須提供的一個方法,用於獲取 Uri 對象所對應的 MIME 類型。一個內容 URI 所對應的 MIME
字符串主要由三部分組分,Android 對這三個部分做了如下格式規定。
1. 必須以 vnd 開頭。
2. 如果內容 URI 以路徑結尾,則後接 android.cursor.dir/,如果內容 URI 以 id 結尾,則後接 android.cursor.item/。
3. 最後接上 vnd.authority.path。
所以,對於 content://com.example.app.provider/table1 這個內容 URI,它所對應的 MIME類型就可以寫成:
vnd.android.cursor.dir/vnd.com.example.app.provider.table1
對於 content://com.example.app.provider/table1/1 這個內容 URI,它所對應的 MIME 類型就可以寫成:
vnd.android.cursor.item/vnd. com.example.app.provider.table1
自定義ContentProvider
public class MyProvider extends ContentProvider {
public static final int BOOK_DIR = 0;
public static final int BOOK_ITEM = 1;
public static final int CATEGARY_DIR = 2;
public static final int CATEGARY_ITEM = 3;
public static final String AUTHORITY = "com.xu.demo_sqllite.provider";
private static UriMatcher uriMarcher;
private MyDatabaseHelper dbHelper;
static {
uriMarcher = new UriMatcher(UriMatcher.NO_MATCH);
uriMarcher.addURI(AUTHORITY, "book", BOOK_DIR);
uriMarcher.addURI(AUTHORITY, "book/#", BOOK_ITEM);
uriMarcher.addURI(AUTHORITY, "catagary", CATEGARY_DIR);
uriMarcher.addURI(AUTHORITY, "catagary/#", CATEGARY_ITEM);
}
@Override
public boolean onCreate() {
dbHelper = new MyDatabaseHelper(getContext(), "BookStore.db", null, 2);
return true;
}
@Override
public Cursor query(Uri uri, String[] projection, String selection,
String[] selectionArgs, String sortOrder) {
SQLiteDatabase database = dbHelper.getReadableDatabase();
Cursor cursor = null;
switch (uriMarcher.match(uri)) {
case BOOK_DIR:
// 查詢所有的書
cursor = database.query("Book", projection, selection,
selectionArgs, null, null, sortOrder);
break;
case BOOK_ITEM:
// 查詢單行書
String bookId = uri.getPathSegments().get(1);
cursor = database.query("Book", projection, "id=?",
new String[] { bookId }, null, null, sortOrder);
break;
case CATEGARY_DIR:
cursor = database.query("Categary", projection, selection,
selectionArgs, null, null, sortOrder);
break;
case CATEGARY_ITEM:
String catagaryId = uri.getPathSegments().get(1);
cursor = database.query("Categary", projection, "id=?",
new String[] { catagaryId }, null, null, sortOrder);
break;
default:
break;
}
return cursor;
}
@Override
public String getType(Uri uri) {
switch (uriMarcher.match(uri)) {
case BOOK_DIR:
return "vnd.android.cursor.dir/vnd.com.xu.demo_sqllite.provider.book";
case BOOK_ITEM:
return "vnd.android.cursor.dir/vnd.com.xu.demo_sqllite.provider.book";
case CATEGARY_DIR:
return "vnd.android.cursor.dir/vnd.com.xu.demo_sqllite.provider.categary";
case CATEGARY_ITEM:
return "vnd.android.cursor.dir/vnd.com.xu.demo_sqllite.provider.categary";
default:
break;
}
return null;
}
@Override
public Uri insert(Uri uri, ContentValues values) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
Uri uriReturn = null;
switch (uriMarcher.match(uri)) {
case BOOK_DIR:
case BOOK_ITEM:
long newBookId = db.insert("Book", null, values);
uriReturn = Uri.parse("content://" + AUTHORITY + "/book/"
+ newBookId);
break;
case CATEGARY_DIR:
case CATEGARY_ITEM:
long newCategaryId = db.insert("Categary", null, values);
uriReturn = Uri.parse("content://" + AUTHORITY + "/categary/"
+ newCategaryId);
break;
default:
break;
}
return uriReturn;
}
@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
int deleteRows = 0;
switch (uriMarcher.match(uri)) {
case BOOK_DIR:
deleteRows = db.delete("Book", selection, selectionArgs);
break;
case BOOK_ITEM:
String bookId = uri.getPathSegments().get(1);
deleteRows = db.delete("Book", "id=?", new String[] { bookId });
break;
case CATEGARY_DIR:
deleteRows = db.delete("CategaryId", selection, selectionArgs);
break;
case CATEGARY_ITEM:
String categaryId = uri.getPathSegments().get(1);
deleteRows = db.delete("CategaryId", "id=?",
new String[] { categaryId });
break;
default:
break;
}
return deleteRows;
}
@Override
public int update(Uri uri, ContentValues values, String selection,
String[] selectionArgs) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
int updateRows = 0;
switch (uriMarcher.match(uri)) {
case BOOK_DIR:
updateRows = db.update("Book", values, selection, selectionArgs);
break;
case BOOK_ITEM:
String bookId = uri.getPathSegments().get(1);
updateRows = db.update("Book", values, "id=?",
new String[] { bookId });
break;
case CATEGARY_DIR:
updateRows = db
.update("Categary", values, selection, selectionArgs);
break;
case CATEGARY_ITEM:
String categaryId = uri.getPathSegments().get(1);
updateRows = db.update("Categary", values, "id=?",
new String[] { categaryId });
break;
default:
break;
}
return updateRows;
}
}
AndroidMinafest.xml配置
<provider
android:name="com.xu.demo_sqllite.MyProvider"
android:authorities="com.xu.demo_sqllite.provider"
android:exported="true"
></provider>
實現跨程序數據共享
public class MainActivity extends Activity {
private String newId;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button addData = (Button) findViewById(R.id.add_data);
addData.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
Uri uri=Uri.parse("content://com.xu.demo_sqllite.provider/book");
System.err.println("--------------"+uri);
ContentValues values = new ContentValues();
values.put("name", "A Clash of Kings");
values.put("author", "George Martin");
values.put("pages", 1040);
values.put("price", 22.85);
Uri newUri=getContentResolver().insert(uri, values);
newId=newUri.getPathSegments().get(1);
}
});
Button queryData = (Button) findViewById(R.id.query_data);
queryData.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// 查詢數據
Uri uri = Uri
.parse("content://com.xu.demo_sqllite.provider/book");
Cursor cursor = getContentResolver().query(uri, null, null,
null, null);
if (cursor != null) {
while (cursor.moveToNext()) {
String name = cursor.getString(cursor
.getColumnIndex("name"));
String author = cursor.getString(cursor
.getColumnIndex("author"));
int pages = cursor.getInt(cursor
.getColumnIndex("pages"));
double price = cursor.getDouble(cursor
.getColumnIndex("price"));
Log.i("MainActivity", "book name is " + name);
Log.i("MainActivity", "book author is " + author);
Log.i("MainActivity", "book pages is " + pages);
Log.i("MainActivity", "book price is " + price);
}
cursor.close();
}
}
});
Button updateData = (Button) findViewById(R.id.update_data);
updateData.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// 更新數據
Uri uri = Uri
.parse("content://com.xu.demo_sqllite.provider/book/"
+ newId);
ContentValues values = new ContentValues();
values.put("name", "A Storm of Swords");
values.put("pages", 1216);
values.put("price", 24.05);
getContentResolver().update(uri, values, null, null);
}
});
Button deleteData = (Button) findViewById(R.id.delete_data);
deleteData.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// 刪除數據
Uri uri = Uri
.parse("content://com.xu.demo_sqllite.provider/book/"
+ newId);
getContentResolver().delete(uri, null, null);
}
});
}
}
經過運行,可以ProviderTest程序可以對sqlliteTest的數據庫進行增刪查改。