How use custom libsqlite3.so with Android Room(Android房间如何使用自定义libsqlite3.so)
问题描述
我在Android版本7或更早版本的设备上使用Android Room时发现问题。
问题是sqlite3中的printf
函数具有三位数分隔符功能,但此功能在旧版本的库中不可用。
我决定将sqlite3库附加到我的应用程序,以便我的应用程序将使用特定版本的sqlite3。
我按照SQLite Android Bindings中的说明使用我的应用程序构建了AAR文件。但是我必须使用org.sqlite.database.sqlite.SQLiteDatabase
类才能在AAR中使用sqlite库。
如果为sqlite访问编写自己的包装也可以,但是当我使用Android Room时,有没有办法强制Room使用org.sqlite.database.sqlite.SQLiteDatabase
而不是Android版本。
推荐答案
有实现(感谢bwt) for more detail
Gradle文件
dependencies {
...
implementation 'io.requery:sqlite-android:3.34.1'
...
}
应用程序类
database = Room.databaseBuilder(context, MyDB.class, "app.db")
...
.openHelperFactory(new RequerySQLiteOpenHelperFactory())
...
.build();
dao = database.getDao();
这篇关于Android房间如何使用自定义libsqlite3.so的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!