在Android Q中引入了新的范围存储功能,该功能表示:
默认情况下,面向Android 10(API级别29)及更高版本的应用会获得对外部存储(或范围存储)的范围内访问权限。此类应用程序只能访问外部存储上特定于应用程序的目录以及该应用程序创建的特定媒体类型。
我有我的应用程序在外部存储上创建SQLite数据库,这样,当应用程序卸载数据库时,该数据库仍然有效,以后可以用作恢复功能,也可以在Android设备之外使用(例如在PC中)
如何使用Android Q达到相同的效果?更准确地说,如果数据库存储在外部公共目录中,如何使用标准读取此数据库SQLiteOpenHelper
?
您至少不能使用框架SQLite或支持的SQLite AndroidX API(Room使用的API)。我不能排除使用自定义编译的SQLite库以及文件描述符的一些晦涩的解决方案。
—
CommonsWare
不,不。不,不,不!我不敢相信,必须有一种方法可以使用放在公共目录中的SQLite数据库...
—
Barmaley Red Star
在启动和关闭应用程序时,您可以复制数据库文件。使用媒体存储,您不需要权限。
—
blackapps
@blackapps,虽然我很高兴也可以采用其他方法,但我当然也理解此选项:直接访问外部存储上的SQLite数据库
—
Barmaley Red Star