ContentProvider示例

1.创建数据提供者数据库

public class DBhelper extends SQLiteOpenHelper {

    public DBhelper(Context context){
        super(context,"test.db",null,1);
    }

    @Override
    public void onCreate(SQLiteDatabase sqLiteDatabase) {
        String sqlCreateTable ="create Table t_test ( id  integer primary key autoincrement , name text )";
        sqLiteDatabase.execSQL(sqlCreateTable);
    }

    @Override
    public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {

    }
}

2.创建数据提供接口页面,继承ContentProvider

public class MyContentProvider extends ContentProvider {


    private DBhelper dbhelper;
    private SQLiteDatabase dataBase;

    @Override
    public boolean onCreate() {
        dbhelper = new DBhelper(getContext());
        dataBase = dbhelper.getReadableDatabase();
        return false;
    }

    @Override
    public String getType(Uri uri) {
        return "";
    }

    @Nullable
    @Override
    public Cursor query(@NonNull Uri uri, @Nullable String[] projection, @Nullable String selection, @Nullable String[] selectionArgs, @Nullable String sortOrder) {
        Cursor cursor = null;
        cursor = dataBase.query(uri.getLastPathSegment(), projection, selection, selectionArgs, null, null, sortOrder);
        return cursor;
    }

    @Nullable
    @Override
    public Uri insert(@NonNull Uri uri, @Nullable ContentValues contentValues) {
        return null;
    }

    @Override
    public int delete(@NonNull Uri uri, @Nullable String s, @Nullable String[] strings) {
        return 0;
    }

    @Override
    public int update(@NonNull Uri uri, @Nullable ContentValues contentValues, @Nullable String s, @Nullable String[] strings) {
        return 0;
    }
}

3.注册

        <provider
            android:authorities="com.czos.exp"
            android:exported="true"
            android:name=".MyContentProvider">
        </provider>

4.B程序中调用数据

        String uriStr ="content://com.czos.exp/t_test";
        Uri uri  = Uri.parse(uriStr);
        contentS = getContentResolver();
        Cursor cursor = contentS.query(uri,null,null,null,null);
        while (cursor.moveToNext()){
            int id =cursor.getInt(0);
            String name =cursor.getString(1);
            Log.d("ContentResolver","id:"+id+" name:"+name);
        }

源代码

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,803评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,906评论 25 709
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,275评论 18 399
  • 青春年少时,我觉得我的梦想就是做一女强人,至于进厨房,结婚,生小孩这些传统女性必须要面对的,我通通都不想。 然而,...
    果果菠萝蜜妈妈姗妮谢阅读 5,707评论 2 5
  • 清风微醺在露珠沾满莲的雨季 你就这样毫无防备出现在我的世界里 眉眼含笑看着花苞待放的美丽 无法言语的深情 诉说着淳...
    花的呢喃阅读 721评论 0 0

友情链接更多精彩内容