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

时间:2017-11-14 16:41:21

标签: android android-room

我正在开发一个琐事应用程序,我已经完成了对应用程序中的Room Persistence的实现,但是我无法找到信息,我可以从SQLite db文件中导入现有的表格。与应用程序一起发货。

1 个答案:

答案 0 :(得分:2)

似乎有点迟了但我通过这个解决方案解决了这个问题。 在初始化房间数据库之前,您需要将现有的sqlite db文件复制到/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();
}

然后在你的应用程序类中执行以下操作:

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

}

在我的情况下,我使用匕首初始化房间作为依赖