android sql大小,android SQL 优化

首先是jdbc 使用的是 SQLiteDatabase

/** * 连接数据库 * @param db * @return */ public static SQLiteDatabase connection(@NotNull String db) { return sqLiteDatabase = SQLiteDatabase.openOrCreateDatabase(db, null); }

然后我这边是读的流文件,考虑到内存大小和文件内容未知

采用读一行插一行

``

/**

* 将文件读成string

*/

private fun readFileAsString(url: String,insert:(s:String) -> String) {

var file =File(url)

if(!file.exists()){//不存在

System.out.println("url")

return

}

loading.show();

var thread =Thread({

System.out.println("线程")

var bufferedReader= BufferedReader(FileReader(file))

var line:String?=null

println("开始"+System.currentTimeMillis())

sql.beginTransaction()

while ({line=bufferedReader.readLine();line}()!=null){

//insert(line.toString())

var stmt =sql.compileStatement(insert(line.toString()));

stmt.execute();

stmt.clearBindings();

// println("ff"+System.currentTimeMillis())

}

println("结束"+System.currentTimeMillis())

bufferedReader.close()

sql.setTransactionSuccessful();

sql.endTransaction();

if(insert.equals(::import1)){

var list = dbQuery1()

runOnUiThread {

mList.clear()

mList.addAll(list)

mAdapter.notifyDataSetChanged()

dataImportSearchLL.visibility=View.VISIBLE

loading.dismiss()

}

}else if(insert.equals(::import2)){

var count= dbQuery2()

System.out.println(count)

runOnUiThread {

dataImportJZBNumTv.setText((count/2).toString())

loading.dismiss()

}

}

})

thread.start()

}

``

上面代码就是优化事务,可见他每次插入都开关了事务

插入需要用到SQLiteStatement说明这个就是SQLiteDatabase jdbc的封装的这个

SQLiteStatement可以使用mSQLiteStatement.bindString(1, randomName);来替换sql语句中的 ?占位符。毕竟这个就是为了优化插入的嘛,我直接喜欢用拼好的sql

然后优化效果: 插入数据约2000*40条,

优化前22秒

优化后4秒

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值