如何将现有的 SQLite table 导入 Android Room?

How to import an existing SQLite table into Android Room?

我正在开发一个 trivia 应用程序,我已经完成了在该应用程序中实现 Room Persistence,但是我无法找到可以从我的 SQLite 数据库文件中导入现有 table 的信息m 与应用程序一起发货。

似乎有点晚了,但我通过这个解决方案解决了这个问题。 在初始化房间数据库之前,您需要将现有的 sqlite 数据库文件复制到 /data/data/{your package name}/databases 目录

您可以使用此方法复制文件

   public static void copyDataBase(Context context, String dbName) throws IOException {

    InputStream myInput = context.getAssets().open(dbName); 
    String outFileName =  "/data/data/"
            +context.getApplicationContext().getPackageName()
            + "/databases/" + dbName;
    File file=new File(outFileName);
    if (file.exists())
        return; 
    OutputStream myOutput = new FileOutputStream(outFileName); 
    byte[] buffer = new byte[1024];
    int length;
    while ((length = myInput.read(buffer)) > 0) {
        myOutput.write(buffer, 0, length);

    } 
    myOutput.flush();
    myOutput.close();
    myInput.close();
}

然后在您的应用程序中 class 执行此操作:

public class ErrorReporterInit extends Application  {

public static ApplicationComponent applicationComponent;

@Inject
DispatchingAndroidInjector<Activity> activityDispatchingAndroidInjector; 

@Override
public void onCreate() {
    super.onCreate();

    try {
        GeneralUtil.copyDataBase(this,"{your existing db file in asset}");
    } catch (IOException e) {
        e.printStackTrace();
    }

    applicationComponent = DaggerApplicationComponent.builder()
            .application(this).build();
    applicationComponent.inject(this);

}



@Override
public void onTerminate() {
    super.onTerminate();
}

}

在我的例子中,我使用 dagger

将 room 初始化为依赖项