android – 没有SQL的ContentProvider

我有两个数据需要从外部应用程序访问并存储.根据文档,ContentProviders是唯一可能的方式,但它也提到了外部存储. ContentProviders实现类似数据库的“接口”,对于两个数据,使用数据库是非常不必要的.我宁愿将它们保存到文件中,但是通过实现抽象方法使用ContentProvider是有问题的,因为这些方法被构造为数据库查询.

我知道没有任何指定ContentProviders必须使用下面的数据库来存储数据,但有没有其他方法来存储必须共享到文件系统的最小数据量?

解决方法

我只是使用MatrixCursor来解决这个确切的问题.看看吧.

编辑:对不起,当我回答时,我刚刚扫描了问题. ContentProvider是应用程序共享数据的唯一方式.应用程序中的活动可以使用SharedPreferences来处理较小的数据,并添加持久性.

编辑v2:这是我用来为我的ContentProvider的查询功能填充MatrixCursor的函数.我正在使用我创建的预定义VIEW,它返回一组不同的值,这会设置一个带有_ids的游标,我可以传递给我的ExpandableListView.

private Cursor getFactions() {
        MatrixCursor mc = new MatrixCursor(Model.Faction.PROJECTION);
        sqliteDatabase db = dbHelper.getReadableDatabase();
        Cursor c = db.query(MODELFACTION_TABLE_NAME,new String[] { Model.Faction.FACTION },null,Model.Faction.FACTION + " ASC");
        c.movetoFirst();
        do {
            mc.addRow(new Object[] { c.getPosition(),c.getString(c.getColumnIndex(Model.Faction.FACTION))});               
        } while (c.movetoNext() && ! c.isAfterLast());
        c.close();
        db.close();
        return mc;
    }

相关文章

Android性能优化——之控件的优化 前面讲了图像的优化,接下...
前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要...
最近项目重构,涉及到了数据库和文件下载,发现GreenDao这个...
WebView加载页面的两种方式 一、加载网络页面 加载网络页面,...
给APP全局设置字体主要分为两个方面来介绍 一、给原生界面设...
前言 最近UI大牛出了一版新的效果图,按照IOS的效果做的,页...