Android11更新后,如何在没有外部存储权限的情况下将SQLite数据库转移到另一个设备上?
创始人
2024-08-20 10:30:12
0

在Android 11及以上的设备上,由于Google限制了对外部存储的访问权限,我们需要使用特殊的应用程序间共享方法来进行数据库传输。以下是一种可能的解决方案,其使用ContentProvider进行数据共享。

在发送设备中的应用程序中,需要创建一个ContentProvider类来使另一个设备的应用程序访问数据库。以下是一个示例ContentProvider类:

public class MyContentProvider extends ContentProvider {
    private MyDBHelper mDBHelper;
    @Override
    public boolean onCreate() {
        Context context = getContext();
        mDBHelper = new MyDBHelper(context);
        return true;
    }
    @Nullable
    @Override
    public Cursor query(@NonNull Uri uri, @Nullable String[] projection, @Nullable String selection, @Nullable String[] selectionArgs, @Nullable String sortOrder) {
        SQLiteDatabase db = mDBHelper.getReadableDatabase();
        Cursor cursor = db.query(MyDBHelper.TABLE_NAME,projection,selection,selectionArgs,null,null,sortOrder);
        cursor.setNotificationUri(getContext().getContentResolver(),uri);
        return cursor;
    }
    @Nullable
    @Override
    public Uri insert(@NonNull Uri uri, @Nullable ContentValues values) {
        SQLiteDatabase db = mDBHelper.getWritableDatabase();
        long id = db.insert(MyDBHelper.TABLE_NAME,null,values);
        if(id != -1){
            getContext().getContentResolver().notifyChange(uri,null);
            return ContentUris.withAppendedId(uri,id);
        }
        return null;
    }
    ...
    //其他ContentProvider方法
}

在另一个设备的应用程序中,您可以使用ContentResolver来访问ContentProvider并进行数据库操作。以下是一个示例:

public class MyActivity extends AppCompatActivity {
    private static final String AUTHORITY = "com.example.mycontentprovider";
    private static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/" + MyDBHelper.TABLE_NAME);
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

相关内容

热门资讯

分享给玩家"佛手大菠... 分享给玩家"佛手大菠萝辅助"开挂(透视)hh poker辅助有用吗(有人有挂);打开点击测试直接进入...
专业讨论"hhpok... 大家好,今天小编来为大家解答hhpoker有辅助的吗这个问题咨询软件客服可以免费测试直接加微信(13...
技术分享"微信小程序... 技术分享"微信小程序四川微乐脚本"开挂(透视)哈糖大菠萝能开挂吗(真是有挂)《详细加薇1367043...
重大通报"皇豪互娱科... 重大通报"皇豪互娱科技软件"开挂(透视)wepoker数据分析(有挂方式);打开点击测试直接进入微信...
重大发现"微信传送屋... 【亲,微信传送屋辅助器下载 这款游戏可以开挂的,确实是有挂的,很多玩家在这款微信传送屋辅助器下载中打...
实测发现"广东雀神智... 实测发现"广东雀神智能插件辅助脚本"开挂(透视)wepoker免费脚本咨询(有挂秘籍)【无需打开直接...
每日必看教程"建德十... 每日必看教程"建德十三道辅助"开挂(透视)aapoker插件下载(了解有挂) 了解更多开挂安装加(1...
玩家必看秘籍"红河西... 您好:这款红河西元旗牌脚本游戏是可以开挂的,确实是有挂的,很多玩家在这款红河西元旗牌脚本游戏中打牌都...
揭秘几款"四川长牌辅... 揭秘几款"四川长牌辅助"开挂(透视)wepoker破解器(有挂技术);无需打开直接搜索薇:13670...
终于知道"陕西辅助&... 终于知道"陕西辅助"开挂(透视)哈糖大菠萝能开挂吗(有挂实锤)这是一款可以让一直输的玩家,快速成为一...