package com.qmusic.dal; import android.content.ContentProvider; import android.content.ContentValues; import android.content.UriMatcher; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.net.Uri; import com.qmusic.uitls.BLog; public class BContentProvider extends ContentProvider { static final String TAG = "BContentProvider"; public static final String AUTHORITY = "com.qmusic.provider"; public static final Uri TEST_CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/" + TestTable.TABLE_NAME); public static final Uri COMMON_CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/" + CommonTable.TABLE_NAME); private UriMatcher sMatcher; public static final int SCHEME_COMMON = 1; public static final int SCHEME_TEST = 2; @Override public String getType(Uri uri) { return null; } @Override public boolean onCreate() { sMatcher = new UriMatcher(UriMatcher.NO_MATCH); sMatcher.addURI(AUTHORITY, CommonTable.TABLE_NAME, SCHEME_COMMON); sMatcher.addURI(AUTHORITY, TestTable.TABLE_NAME, SCHEME_TEST); return true; } @Override public Uri insert(Uri uri, ContentValues values) { SQLiteDatabase db = BDatabaseHelper.getDatabase(); long result = 0; switch (sMatcher.match(uri)) { case SCHEME_COMMON: { result = db.insert(CommonTable.TABLE_NAME, null, values); break; } case SCHEME_TEST: { result = db.insert(TestTable.TABLE_NAME, null, values); break; } default: throw new IllegalArgumentException("Unknown URI" + uri); } if (result > 0) { getContext().getContentResolver().notifyChange(uri, null); } Uri newUri = uri.buildUpon().appendPath(String.valueOf(result)).build(); BLog.i(TAG, "insert:" + newUri.toString()); return newUri; } @Override public int delete(Uri uri, String selection, String[] selectionArgs) { SQLiteDatabase db = BDatabaseHelper.getDatabase(); int result = 0; switch (sMatcher.match(uri)) { case SCHEME_COMMON: { result = db.delete(CommonTable.TABLE_NAME, selection, selectionArgs); break; } case SCHEME_TEST: result = db.delete(TestTable.TABLE_NAME, selection, selectionArgs); break; default: throw new IllegalArgumentException("Unknown URI" + uri); } if (result > 0) { getContext().getContentResolver().notifyChange(uri, null); } BLog.i(TAG, "delete:" + uri.toString() + ";result:" + result); return result; } @Override public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) { SQLiteDatabase db = BDatabaseHelper.getDatabase(); Cursor cursor = null; switch (sMatcher.match(uri)) { case SCHEME_COMMON: { cursor = db.query(CommonTable.TABLE_NAME, projection, selection, selectionArgs, null, null, sortOrder); break; } case SCHEME_TEST: { cursor = db.query(TestTable.TABLE_NAME, projection, selection, selectionArgs, null, null, sortOrder); break; } default: throw new IllegalArgumentException("Unknown URI" + uri); } cursor.setNotificationUri(getContext().getContentResolver(), uri); BLog.i(TAG, "query:" + uri.toString()); return cursor; } @Override public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) { SQLiteDatabase db = BDatabaseHelper.getDatabase(); int result = 0; switch (sMatcher.match(uri)) { case SCHEME_COMMON: { result = db.update(CommonTable.TABLE_NAME, values, selection, selectionArgs); break; } case SCHEME_TEST: { result = db.update(TestTable.TABLE_NAME, values, selection, selectionArgs); break; } default: throw new IllegalArgumentException("Unknown URI" + uri); } if (result > 0) { getContext().getContentResolver().notifyChange(uri, null); } BLog.i(TAG, "update:" + uri.toString()); return result; } }