当前位置:  开发笔记 > 数据库 > 正文

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

如何解决《Android:在sqlite数据库中插入多行无法正常工作》经验,为你挑选了2个好方法。

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

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

它工作正常.我看到这个链接在sqlite数据库中插入多行.我在我的android项目中尝试这种方法(插入多行),但它不起作用.

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

怎么做?



1> piotrpo..:

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

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

myDb.beginTransaction();
   for(){ myDb.execSQL() }
myDb.setTransactionSuccessful();
myDb.endTransaction();

主要思想是不在每个插入的行上写入物理数据库文件,而是每隔几行写一次.在其他只要插入的数据不会持久存储在"驱动器"上它就在内存中.对于小数据集,您只需启动事务,在一个块中进行所有插入和结束事务.

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

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


注意:您需要在`endTransaction()`之前调用`myDb.setTransactionSuccessful();`以便提交更改.

2> Kapil Vats..:

多行插入仅适用于SQLite 3.7.11或更高版本,但只有jellybean和kitkat支持Sqlite 3.7.11

推荐阅读
k78283381
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有