android数据库 批量 事务 操作
来源:互联网 发布:疯狂java讲义怎么样 编辑:程序博客网 时间:2024/05/17 06:06
先说说多线程 数据库sqlite问题:
1:多线程 单例 SQLiteOpenHelper 可以同时读和写。
2.多线程 多个对象 SQLiteOpenHelper 不能同时读写(可以同时读)。
3.多线程事务(1个读写过程就是一个事务,推荐以后都用事务的方式,对于大量的数据)
4.事务写法:
1. 使用db.execSQL(sql)
- public void inertOrUpdateDateBatch(List<String> sqls) {
- SQLiteDatabase db = getWritableDatabase();
- db.beginTransaction();
- try {
- for (String sql : sqls) {
- db.execSQL(sql);
- }
- // 设置事务标志为成功,当结束事务时就会提交事务
- db.setTransactionSuccessful();
- } catch (Exception e) {
- e.printStackTrace();
- } finally {
- // 结束事务
- db.endTransaction();
- db.close();
- }
- }
2. 使用db.insert("table_name", null, contentValues)
- db.beginTransaction(); // 手动设置开始事务
- for (ContentValues v : list) {
- db.insert("bus_line_station", null, v);
- }
- db.setTransactionSuccessful(); // 设置事务处理成功,不设置会自动回滚不提交
- db.endTransaction(); // 处理完成
- db.close();
3. 使用InsertHelper类
这个类在API 17中已经被废弃了,参考博客:http://www.outofwhatbox.com/blog/2010/12/android-using-databaseutils-inserthelper-for-faster-insertions-into-sqlite-database/
- InsertHelper ih = new InsertHelper(db, "bus_line_station");
- db.beginTransaction();
- final int directColumnIndex = ih.getColumnIndex("direct");
- final int lineNameColumnIndex = ih.getColumnIndex("line_name");
- final int snoColumnIndex = ih.getColumnIndex("sno");
- final int stationNameColumnIndex = ih.getColumnIndex("station_name");
- try {
- for (Station s : busLines) {
- ih.prepareForInsert();
- ih.bind(directColumnIndex, s.direct);
- ih.bind(lineNameColumnIndex, s.lineName);
- ih.bind(snoColumnIndex, s.sno);
- ih.bind(stationNameColumnIndex, s.stationName);
- ih.execute();
- }
- db.setTransactionSuccessful();
- } finally {
- ih.close();
- db.endTransaction();
- db.close();
- }
4. 使用SQLiteStatement
查看InsertHelper时,官方文档提示改类已经废弃,请使用SQLiteStatement,链接:https://developer.android.com/reference/android/database/DatabaseUtils.InsertHelper.html 该方法类似于JDBC里面的预编译sql语句,使用方法如下:
- 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();
下图是以上4中方法在批量插入1万条数据消耗的时间
可以发现第三种方法需要的时间最短,鉴于该类已经在API17中废弃,所以第四种方法应该是最优的方法。
0 0
- android数据库 批量 事务 操作
- android数据库 批量 事务 操作
- android数据库 批量 事务 操作
- Android数据库批量操作
- android数据库事务操作
- Android数据库事务操作
- android数据库事务操作
- Android数据库事务操作
- Android 数据库事务操作
- Android sqlite3 数据库批量操作
- Android 数据库批量操作_ContentProviderOperations
- android数据库事务操作详解
- 使用事务操作android 数据库
- c#批量插入数据到数据库【支持事务操作】
- c#批量插入数据到数据库【支持事务操作】
- Android数据库操作之--批量插入
- Android数据库批量操作的性能优化
- Android 数据库批量查询数据的操作
- TopCoder SRM 670 Div2 Problem 1050 - Treestrat (floyd)
- 雪碧图 CSS sprite 优化性能
- Axure快捷键
- 【软考4】编程语言的发展和特点
- eclipse部署WEB项目时经常遇到的问题
- android数据库 批量 事务 操作
- HDU 5500 Reorder the Books
- 3.3.8 使用difflib.ndiff函数
- [UE]《设计师要懂心理学》简要
- java,Substring简单用法
- ?不明确类型,占位符
- Ubuntu编写shell脚本
- 解决struts2中无法使用<sx:,datetimepicker无法显示以及显示成乱码
- javascript基础教程第8版---第5章窗口与框架---学习笔记