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透视方... 透视辅助!wepoker透视方法,微乐自建房脚本使用安全吗,了解脚本(有挂总结)-哔哩哔哩wepok...
脚本透视!hhpkoer辅助挂... 脚本透视!hhpkoer辅助挂是真的吗,hhpoker有后台操作吗(透视)确实真的是有挂(哔哩哔哩)...
据玩家消息!wepoker软件... 据玩家消息!wepoker软件安装包,微乐自建房辅助神器怎么安装,教你脚本(确实有挂)-哔哩哔哩1、...
透视攻略!德州局HHpoker... 透视攻略!德州局HHpoker透视脚本,微乐小程序辅助开发透视,有挂脚本(有挂技巧)-哔哩哔哩1、德...
透视开挂!hhpoker辅助,... 透视开挂!hhpoker辅助,hh poker辅助器先试用(透视)其实是真的软件(哔哩哔哩)暗藏猫腻...
透视分享!aapoker辅助器... 透视分享!aapoker辅助器是真的吗,aapoker怎么开辅助器(透视)好像存在有挂(哔哩哔哩)1...
值得注意的是!线上德州的辅助器... 值得注意的是!线上德州的辅助器是什么,广西微乐小程序微信辅助器免费,详情透视(有挂方针)-哔哩哔哩1...
透视了解!aapoker如何设... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】很多玩家在这款游戏中打...
透视攻略!hhpoker软件安... 透视攻略!hhpoker软件安装包,微乐小游戏万能修改器,详情透视(有挂秘诀)-哔哩哔哩亲,关键说明...
透视专业!wpk透视辅助下载,... 透视专业!wpk透视辅助下载,wpk模拟器是什么(透视)好像是真的工具(哔哩哔哩)脚本下载中分为三种...