加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

优化SQLite3数据库插入10000条数据

发布时间:2020-12-12 19:51:34 所属栏目:百科 来源:网络整理
导读:如果用普通的方式向数据库中插入10000条数据,会不会妨碍用户体验呢?答案是肯定会,那么如何优化我们的数据库的各种操作呢。 (1)使用事务。 String sql = "insert into bus_line_station(direct,line_name,sno,station_name) values(?,?,?)"; SQLiteState

如果用普通的方式向数据库中插入10000条数据,会不会妨碍用户体验呢?答案是肯定会,那么如何优化我们的数据库的各种操作呢。

(1)使用事务。

 String sql = "insert into bus_line_station(direct,line_name,sno,station_name) values(?,?,?)";
        SQLiteStatement stat = db.compileStatement(sql);
        db.beginTransaction();
        for (Station line : busLines) {
            stat.bindLong(1,line.direct);
            stat.bindString(2,line.lineName);
            stat.bindLong(3,line.sno);
            stat.bindString(4,line.stationName);
            stat.executeInsert();
        }
        db.setTransactionSuccessful();
        db.endTransaction();
        db.close();
可以大大减少插入数据库所需的时间。

那么为啥呢?你如果是普通的插入数据库的方法的话,插入10000条数据需要执行10000次的 事务开始+执行sql+事务结束,而上面事务开始和事务结束只执行了一次。大部分的时间实在执行sql。

(2)http://blog.csdn.net/hustpzb/article/details/6600591 这个不知道好使不好使。

(3)开启一个线程,执行完插入数据库的操作之后通过Handler来发消息。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读