从CSV文件填充Android数据库?

时间:2010-05-22 05:57:41

标签: database android import sqlite

是否可以将存储在res / raw资源目录中的csv文件用于填充sqlite3数据库中的表?

我的想法是,如果有办法将整个文件批量导入到表中,那么这将比在文件中的每一行迭代并执行单独的插入语句更清晰,更快......

我发现有一个sqlite import命令允许这样:How to import load a .sql or .csv file into SQLite?

...但我在Android应用程序中应用这些语句时遇到了问题。我的第一个想法是尝试类似下面的东西......但没有运气:

db.execSQL("CREATE TABLE " + TABLE_NAME + "(id INTEGER PRIMARY KEY, name TEXT)");
db.execSQL(".mode csv");
db.execSQL(".import res/raw/MyFile.csv " + TABLE_NAME); 

这可能吗?

我应该尝试不同的方法来填充我的数据库吗?

更新:我将Josef的回复标记为答案(使用交易批量插入),因为它工作正常并根据我的标题直接回答我的问题(感谢Josef)。但是,我仍然在寻找一种方法,使用import语句在csv文件中将Android应用程序批量插入到sqlite3表中。如果你知道怎么做,请回复。

谢谢你的答案!

2 个答案:

答案 0 :(得分:30)

如果要将静态数据打包到应用程序中,我建议在开发时准备数据库(使用您喜欢的任何UI或csv-import命令)并将sqlite文件发送到assets文件夹中。然后,您可以在首次运行应用程序时将整个sqlite文件复制到设备上。 These posts带您了解这个最有可能设置数据库的方法(文件复制速度)。

如果出于某种原因,您确实需要在运行时插入大量数据,我建议您查看bulk insert using transactions加快速度的方法。

答案 1 :(得分:14)

我花了很多时间寻找一个简单的解决方案,并自己想出了一些代码。对于未来的人来说,就像我一样,你可以使用它:

BufferedReader in = new BufferedReader(your csv file source here);
String reader = "";
while ((reader = in.readLine()) != null){
    String[] RowData = reader.split(",");
    date = RowData[0];
    value = RowData[1];
    ContentValues values = new ContentValues();
    values.put(CsvProvider.DATE, date);
    values.put(CsvProvider.VALUE, value);
    getContentResolver().insert(CsvProvider.CONTENT_URI, values);
}
in.close();

我的CSV文件没有标题,只有2列,但不应该有两列以上。只需记住指定拆分列的内容,并为每列添加另一个RowData[#](您必须从0开始)。在调用in.close()之前,您需要确保完成每行的操作。我正在使用内容提供商,但您可以使用数据执行任何操作,例如将其附加到String[]或其他任何内容。

当我使用输入流时,您可以将BufferedReader指向您想要的任何位置。只要BufferedReader可以读取它,它就会起作用。