android批量插入数据效率对比
对比在android中批量插入数据的3中方式对比(各插入1W条数据所花费的时间):
1、 一个一个插入
- /**
- * 向表中插入数据
- *
- * @param openHelper
- * @param appInfo
- * @return
- */
- public static boolean insert(SQLiteOpenHelper openHelper,
- RemoteAppInfo appInfo) {
- if (null == appInfo) {
- return true;
- }
- SQLiteDatabase db = null;
- try {
- db = openHelper.getWritableDatabase();
- ContentValues values = appInfo.getContentValues();
- != db.insert(RemoteDBHelper.TABLE_APP_REMOTE, null,
- values);
- } catch (Exception e) {
- e.printStackTrace();
- } finally {
- if (null != db) {
- db.close();
- }
- }
- return false;
- }
- for (RemoteAppInfo remoteAppInfo : list) {
- RemoteDBUtil.insert(helper, remoteAppInfo);
- }
耗时:106524ms,也就是106s
2、 开启事务批量插入,使用
SqliteDateBase中的
insert(String table, String nullColumnHack, ContentValues values)
方法
- /**
- * 向表中插入一串数据
- *
- * @param openHelper
- * @param appInfo
- * @return 如果成功则返回true,否则返回flase
- */
- public static boolean insert(SQLiteOpenHelper openHelper,
- List<RemoteAppInfo> list) {
- boolean result = true;
- ) {
- return true;
- }
- SQLiteDatabase db = null;
- try {
- db = openHelper.getWritableDatabase();
- db.beginTransaction();
- for (RemoteAppInfo remoteAppInfo : list) {
- ContentValues values = remoteAppInfo.getContentValues();
- ) {
- result = false;
- break;
- }
- }
- if (result) {
- db.setTransactionSuccessful();
- }
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- } finally {
- try {
- if (null != db) {
- db.endTransaction();
- db.close();
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- return true;
- }
耗时:2968ms
3、 开启事务批量插入,使用
SQLiteStatement
- /**
- * 第二种方式批量插入(插入1W条数据耗时:1365ms)
- * @param openHelper
- * @param list
- * @return
- */
- public static boolean insertBySql(SQLiteOpenHelper openHelper,
- List<RemoteAppInfo> list) {
- ) {
- return false;
- }
- SQLiteDatabase db = null;
- try {
- db = openHelper.getWritableDatabase();
- String sql = "insert into " + RemoteDBHelper.TABLE_APP_REMOTE + "("
- + RemoteDBHelper.COL_PKG_NAME + ","// 包名
- + RemoteDBHelper.COL_USER_ACCOUNT + ","// 账号
- + RemoteDBHelper.COL_APP_SOURCE + ","// 来源
- + RemoteDBHelper.COL_SOURCE_UNIQUE + ","// PC mac 地址
- + RemoteDBHelper.COL_MOBILE_UNIQUE + ","// 手机唯一标识
- + RemoteDBHelper.COL_IMEI + ","// 手机IMEI
- + RemoteDBHelper.COL_INSTALL_STATUS + ","// 安装状态
- + RemoteDBHelper.COL_TRANSFER_RESULT + ","// 传输状态
- + RemoteDBHelper.COL_REMOTE_RECORD_ID // 唯一标识
- + ") " + "values(?,?,?,?,?,?,?,?,?)";
- SQLiteStatement stat = db.compileStatement(sql);
- db.beginTransaction();
- for (RemoteAppInfo remoteAppInfo : list) {
- , remoteAppInfo.getPkgName());
- , remoteAppInfo.getAccount());
- , remoteAppInfo.getFrom());
- , remoteAppInfo.getFromDeviceMd5());
- , remoteAppInfo.getMoblieMd5());
- , remoteAppInfo.getImei());
- , remoteAppInfo.getInstallStatus());
- , remoteAppInfo.getTransferResult());
- , remoteAppInfo.getRecordId());
- long result = stat.executeInsert();
- ) {
- return false;
- }
- }
- db.setTransactionSuccessful();
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- } finally {
- try {
- if (null != db) {
- db.endTransaction();
- db.close();
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- return true;
- }
耗时:1365ms
android批量插入数据效率对比的更多相关文章
- Android 批量插入数据到SQLite数据库
Android中在sqlite插入数据的时候默认一条语句就是一个事务,因此如果存在上万条数据插入的话,那就需要执行上万次插入操作,操作速度可想而知.因此在Android中插入数据时,使用批量插入的方式 ...
- Android批量插入数据到SQLite数据库
Android中在sqlite插入数据的时候默认一条语句就是一个事务,因此如果存在上万条数据插入的话,那就需要执行上万次插入操作,操作速度可想而知.因此在Android中插入数据时,使用批量插入的方式 ...
- JDBC批量插入数据效率分析
对于需要批量插入数据库操作JDBC有多重方式,本利从三个角度对Statement和PreparedStatement两种执行方式进行分析,总结较优的方案. 当前实现由如下条件: 执行数据库:Mysql ...
- Oracle 逐条和批量插入数据方式对比
创建测试表 create table base_users ( userid varchar2(16), username varchar2(32), passwd var ...
- Oracle 插入数据效率对比
oracle插入数据有多种方式: 将从多个表中查出来的数据插入到临时表中 数据行数 5189597 1.传统方式:直接将数据插入到表中 insert into LLB_BASIC_USER_D_TEM ...
- EF批量插入数据耗时对比
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- MySQL:JDBC批量插入数据的效率
平时使用mysql插入.查询数据都没有注意过效率,今天在for循环中使用JDBC插入1000条数据居然等待了一会儿 就来探索一下JDBC的批量插入语句对效率的提高 首先进行建表 create tabl ...
- 批量插入数据(基于Mybatis的实现-Oracle)
前言:做一个数据同步项目,要求:同步数据不丢失的情况下,提高插入性能. 项目DB框架:Mybatis.DataBase:Oracle. -------------------------------- ...
- SpringBoot(18)---通过Lua脚本批量插入数据到Redis布隆过滤器
通过Lua脚本批量插入数据到布隆过滤器 有关布隆过滤器的原理之前写过一篇博客: 算法(3)---布隆过滤器原理 在实际开发过程中经常会做的一步操作,就是判断当前的key是否存在. 那这篇博客主要分为三 ...
随机推荐
- Atitti cto的日常流程与职责attilax总结
Atitti cto的日常流程与职责attilax总结 1. (最重要)技术战略制定 规划,预测趋势1 1.1. 关键词 Throught技术雷达 趋势 没落 已死 辉煌 未来1 1.2. (比较 ...
- vue2.x 路由懒加载 优化打包体积
当打包构建应用时,Javascript 包会变得非常大,影响页面加载.如果我们能把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件,这样就更加高效了. 结合 Vue 的异步组 ...
- Zlib库的安装与使用
在实际应用中经常会遇到要压缩数据的问题,常见的压缩格式有zip和rar,而Linux下那就更多了,bz2,gz,xz什么的都有,单单Linux下的解压和压缩命令就有好多呢?没有什么好不好的.查了资料, ...
- socket.io笔记一
//服务端代码 var server = require('http').createServer(app); var io = require('socket.io')(server,{path:' ...
- C语言发展历程及其保留字(关键字)——附:C语言标准文档
引言 抽时间对C语言发展历程和C语言的标准库文件及其保留字/关键字做了个梳理,后面附C语言各版本国际标准. C语言发展历程及其标准库 C语言关键字/保留字 C语言国际标准 ...
- artificial%20intelligence%20a%20modern%20approach
http://stpk.cs.rtu.lv/sites/all/files/stpk/materiali/mi/artificial%20intelligence%20a%20modern%20app ...
- (原创)C++11改进我们的程序之简化我们的程序(七)
这次要讲的内容是:c++11中的tuple(元组).tuple看似简单,其实它是简约而不简单,可以说它是c++11中一个既简单又复杂的东东,关于它简单的一面是它很容易使用,复杂的一面是它内部隐藏了太多 ...
- DIOCP开源项目-DIOCP3的重生和稳定版本发布
DIOCP3的重生 从开始写DIOCP到现在已经有一年多的时间了,最近两个月以来一直有个想法做个 30 * 24 稳定的企业服务端架构,让程序员专注于逻辑实现就好.虽然DIOCP到现在通讯层已经很稳定 ...
- 远程mysql导入本地文件
远程mysql导入本地文件 登陆数据库 mysql --local-infile -h<IP> -u<USR> -p 选择数据库 USE xxx 导入文件 LOAD DATA ...
- Maven mvn install 本地jar添加到maven仓库中
最近在使用支付宝.财付通这样的第三方支付,在使用支付宝过程中需要引入官方SDK方便开发,使用以下命令来将本地的jar装载到maven仓库中. 这里有几点需要注意点,我使用Windows10时,使用po ...