我有一个 CSV 文件assets包含超过 10000 行数据的文件夹。我想在创建数据库时将此数据插入到 SQLite 数据库中。我无法包含数据库,因为它是一个非常通用的应用程序,并且模型需要 CSV 文件。我不想一次性读取所有 10000 行数据并将其从内存中插入。如何有效、高效地完成任务?
只需插入立即地一旦你读完这句话。因此,不要将这些行存储在内存中的某些数组列表中。
E.g.
while ((line = reader.readLine()) != null) {
insert(line);
}
您可能希望在单个事务中执行此操作,以便在中途失败时可以回滚。在 JDBC 方面,您可能需要考虑PreparedStatement#addBatch()
/#executeBatch()
批量执行插入。可以在以下位置找到示例:这个答案 https://stackoverflow.com/questions/4355046/java-insert-multiple-rows-into-mysql-with-preparedstatement/4355097#4355097.
Update:作为一种完全不同但更有效的替代方案,您也可以将 Java 留在故事之外并使用SQLite 提供的 CSV 导入工具 http://www.sqlite.org/cvstrac/wiki/wiki?p=ImportingFiles.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)