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);

相关内容

热门资讯

发现一款!微扑克机制竟然真的有... WePoker透视辅助工具核心要点解析‌,发现一款!微扑克机制竟然真的有挂,微扑克ai人工智能,详细...
专业讨论!微扑克微乐辅助,we... 大家肯定在之前微扑克微乐辅助或者微扑克微乐辅助中玩过专业讨论!微扑克微乐辅助,wePokE软件透明挂...
记者发布(老友广东麻将来牌规律... 记者发布(老友广东麻将来牌规律)竟然真的有挂(透视)详细教程(有挂总结)-哔哩哔哩是一款可以让一直输...
技术分享!拱趴大菠萝出牌规律,... 技术分享!拱趴大菠萝出牌规律,微扑克系统发牌规律,详细教程(有挂详情)-哔哩哔哩;大神普及一款德州a...
新手必备!wopoker系统套... 新手必备!wopoker系统套路,wePokE软件透明挂,详细教程(有挂方法)-哔哩哔哩是一款可以让...
普及知识(微扑克wpk安全的)... 1、普及知识(微扑克wpk安全的)其实真的有挂(透视)详细教程(有挂攻略)-哔哩哔哩。2、微扑克wp...
9瞬间测试(微扑克机制)外挂辅... 9瞬间测试(微扑克机制)外挂辅助助手(透视)的确真的有挂(2025已更新)(哔哩哔哩)是一款可以让一...
玩家必看科普!财神十三张辅助软... 玩家必看科普!财神十三张辅助软件,wepoke软件透明功能实现方法,详细教程(有挂技巧)-哔哩哔哩是...
最新研发!红龙扑克有外挂,we... 最新研发!红龙扑克有外挂,wePOke软件透明挂,详细教程(有挂攻略)-哔哩哔哩;精心打造了俱乐部社...
我来向大家传授!渤海麻将有挂的... 我来向大家传授!渤海麻将有挂的,wepower伙牌,详细教程(有挂教程)-哔哩哔哩是一款可以让一直输...