ContentProvider讲解与实例应用

什么是ContentProviderandroid

是Android的四大组件之一
主要用于不一样的应用程序之间实现数据共享功能web

什么是ContentResolver:数据库

是数据调用者,ContentProvider将数据发布出来,经过ContentResolver对象结合Uri进行调用
经过ContentResolver对象能够调用ContentProvider的增删改查app

什么是Uri:ide

Uri(通用资源标识符 Universal Resource Identifer),表明数据操做的地址,每个ContentProvider发布数据时都会有惟一的地址。
好比:content://(固定写法)+com.android.contacts(包名,可变)+/contacts(path路径)svg

建立自定义ContentProvider的步骤:测试

1.使用SQLite技术,建立好数据库和数据表
2.新建类继承ContentProvider
3.重写6个抽象方法
4.建立UriMatcher,定义Uri规则
5.在Manifest中注册provider
6.ContentResolver对ContentProvider中共享的数据进行增删改查操做this

ContentProvider实例应用
实现效果:(两个app之间进行数据的增删改查).net

1.增:

2.删:

3.改:

4.查:

这里写图片描述
实现代码:插件

1.此次测试是在我已经建立了一个userdbdemo数据库和userdemo数据表的前提下作出的。

若是对数据库的知识不太了解,能够借鉴我写的两篇博客
[SQLite讲解与实例应用]
(https://blog.csdn.net/shaochen2015821426/article/details/79637550)
[使用LitePal插件操做数据库(增删改查)讲解与实例]
(https://blog.csdn.net/shaochen2015821426/article/details/79791232)

2.新建类继承ContentProvider,重写6个抽象方法,建立UriMatcher,定义Uri规则

//新建类继承ContentProvider
public class DatabaseProvider extends ContentProvider {

    private MyDBHelpter myDBHelpter;
    private static final String TAG = "DatabaseProvider";

    //添加整形常亮
    public static final int USER_DIR = 0;
    public static final int USER_ITEM = 1;
    //建立authority
    public static final String AUTHORITY = "com.example.administrator.databasetest.provider";
    //建立UriMatcher对象
    private static UriMatcher uriMatcher;

    //建立静态代码块
    static {
        //实例化UriMatcher对象
        uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
        //能够实现匹配URI的功能
        //参数1:authority 参数2:路径 参数3:自定义代码
        uriMatcher.addURI(AUTHORITY, "userdemo", USER_DIR);
        uriMatcher.addURI(AUTHORITY, "userdemo/#", USER_ITEM);
    }

    public DatabaseProvider() {
        Log.e(TAG, "DatabaseProvider: ");
    }

    //onCreate()方法
    @Override
    public boolean onCreate() {
        //实现建立MyDBHelpter对象
        myDBHelpter = new MyDBHelpter(getContext(), "userdbdemo", null, 1);
        return true;
    }

    //删除数据表数据
    @Override
    public int delete(Uri uri, String selection, String[] selectionArgs) {
        //建立SQLiteDatabase对象
        SQLiteDatabase db = myDBHelpter.getWritableDatabase();
        int deleteInt = 0;
        //匹配uri
        switch (uriMatcher.match(uri)) {
            case USER_DIR:
                //参数1:表名   参数2:约束删除列的名字   参数3:具体行的值
                deleteInt = db.delete("userdemo", selection, selectionArgs);
                break;
            case USER_ITEM:
                String deleteId = uri.getPathSegments().get(1);
                deleteInt = db.delete("userdemo", "id=?", new String[]{deleteId});
                break;
            default:
        }

        return deleteInt;
    }

    //插入数据
    @Override
    public Uri insert(Uri uri, ContentValues values) {
        SQLiteDatabase db = myDBHelpter.getWritableDatabase();
        switch (uriMatcher.match(uri)) {
            case USER_DIR:
            case USER_ITEM:
                //参数1:表名  参数2:没有赋值的设为空   参数3:插入值
                long newUserId = db.insert("userdemo", null, values);
                break;
            default:
                break;
        }
        return null;
    }

    //查询数据
    @Override
    public Cursor query(Uri uri, String[] projection, String selection,
                        String[] selectionArgs, String sortOrder) {
        SQLiteDatabase db = myDBHelpter.getWritableDatabase();
        Cursor cursor = null;
        switch (uriMatcher.match(uri)) {
            case USER_DIR:
                //参数1:表名  其余参数可借鉴上面的介绍
                cursor = db.query("userdemo", projection, selection, selectionArgs, null, null, sortOrder);
                break;
            case USER_ITEM:
                String queryId = uri.getPathSegments().get(1);
                cursor = db.query("userdemo", projection, "id=?", new String[]{queryId}, null, null, sortOrder);
                break;
            default:
        }
        return cursor;

    }

    //更新数据
    @Override
    public int update(Uri uri, ContentValues values, String selection,
                      String[] selectionArgs) {

        SQLiteDatabase db = myDBHelpter.getWritableDatabase();
        int updateRow = 0;
        switch (uriMatcher.match(uri)) {
            case USER_DIR:
                updateRow = db.update("userdemo",values,selection,selectionArgs);
                break;
            case USER_ITEM:
                String updateId = uri.getPathSegments().get(1);
                updateRow = db.update("userdemo",values,"id=?",new String[]{updateId});

                break;
            default:
        }
        return updateRow;
    }

    @Override
    public String getType(Uri uri) {
        throw new UnsupportedOperationException("Not yet implemented");
    }
}

#####3.在Manifest中注册provider

<provider
            android:name=".provider.DatabaseProvider"
            android:authorities="com.example.administrator.databasetest.provider"
            android:enabled="true"
            android:exported="true"></provider>

4.在另外一个程序中启动:

public class MainActivity extends AppCompatActivity implements View.OnClickListener{


    private Button insertBtn;
    private EditText editText;
    private Button deleteBtn;
    private  Button queryBtn;
    private Button updateBtn;

    private  String newId;

    private static final String TAG = "MainActivity";


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        bangID();
    }

    private void bangID() {
        insertBtn = findViewById(R.id.main_insert_btn);
        editText = findViewById(R.id.main_et);
        deleteBtn = findViewById(R.id.main_delete_btn);
        queryBtn = findViewById(R.id.main_query_btn);
        updateBtn = findViewById(R.id.main_update_btn);


        insertBtn.setOnClickListener(this);
        deleteBtn.setOnClickListener(this);
        queryBtn.setOnClickListener(this);
        updateBtn.setOnClickListener(this);


    }

    @Override
    public void onClick(View v) {
        switch(v.getId()){
            case R.id.main_insert_btn:
                String name = editText.getText().toString();
                //建立期待匹配的uri
                Uri uri1 = Uri.parse("content://com.example.administrator.databasetest.provider/userdemo");
                ContentValues values = new ContentValues();
                values.put("name",name);
                //得到ContentResolver对象,调用方法
                getContentResolver().insert(uri1,values);
                break;
            case R.id.main_delete_btn:
                String name1 = editText.getText().toString();
                Uri uri2 = Uri.parse("content://com.example.administrator.databasetest.provider/userdemo");
                getContentResolver().delete(uri2,"name=?",new String[]{name1});
                break;
            case R.id.main_query_btn:
                Uri uri = Uri.parse("content://com.example.administrator.databasetest.provider/userdemo");
                Cursor cursor = getContentResolver().query(uri,null,null,null,null);
                cursor.moveToFirst();
                do{
                    String name2 = cursor.getString(cursor.getColumnIndex("name"));
                    Log.e(TAG, "onClick: "+name2 );

                }while(cursor.moveToNext());
                cursor.close();
                break;
            case R.id.main_update_btn:
                String updateStr = editText.getText().toString();
                Uri uri3 =Uri.parse("content://com.example.administrator.databasetest.provider/userdemo");
                ContentValues values1 = new ContentValues();
                values1.put("name",updateStr);
                getContentResolver().update(uri3,values1,"name=?",new String[]{""});
                break;
            default:
        }

    }
}

over