Android:在sqlite数据库中插入多行无法正常工作

时间:2014-03-15 18:03:02

标签: android sqlite

我使用以下方法为android项目将单行插入数据库。

myDB.execSQL("INSERT INTO "
 + Buss
 + " (BussName, RouteName)"
 + " VALUES ('buss1', 'buss2');");

工作正常。我看到了这个链接Inserting multiple rows in sqlite database。我在我的android项目中尝试这种方法(插入多行),但它不起作用。

myDB.execSQL("INSERT INTO "
 + Buss
 + " (BussName, RouteName)"
 + " VALUES ('buss1', 'buss2'),('buss1', 'buss2'),('buss1', 'buss2');");

怎么做?

2 个答案:

答案 0 :(得分:9)

您需要为每一行调用单独的insert语句。

出于性能原因,您可以将每个呼叫(假设为~20)分组到一个事务中:

myDb.beginTransaction();
   for(<your loop definition>){ myDb.execSQL(<your insert statement>) }
myDb.setTransactionSuccessful();
myDb.endTransaction();

主要思想是不在每个插入的行上写入物理数据库文件,而是每隔几行写一次。其他只要插入的数据不会持续存在&#34;驱动&#34;它在记忆中。对于小型数据集,您只需启动事务,在一个块中进行所有插入和结束事务。

对于更大的数据,您应该缩小交易量。

使用预准备语句而不是标准语句也是一个好主意,因为SQL解释器只需要解析一次查询 - 可以在此处找到更多信息:How do I use prepared statements in SQlite in Android?

答案 1 :(得分:5)

多行插入只能在SQLite 3.7.11或更高版本中使用,但只有jellybean和kitkat支持Sqlite 3.7.11