Android中在sqlite插入数据的时候默认一条语句就是一个事务(All individual SQL Statements, (with rare exceptions like Bulk Inserts with No Log, or Truncate Table) are automaticaly "In a Transaction" whether you explicitly say so or not.. (even if they insert, update, or delete millions of rows).),因此如果存在上万条数据插入的话,那就需要执行上万次插入操作,操作速度可想而知。因此在Android中插入数据时,使用批量插入的方式可以大大提高插入速度。
批量插入的模板如下:
- public void inertOrUpdateDateBatch(List
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();
- }
- }
注意此处的:
- db.execSQL(sql);
官方的API显示:
Added in API level 1
Execute a single SQL statement that is NOT a SELECT or any other SQL statement that returns data.
It has no means to return any data (such as the number of affected rows). Instead, you're encouraged to use insert(String, String, ContentValues)
, update(String, ContentValues, String, String[])
, et al, when possible.
When using enableWriteAheadLogging()
, journal_mode is automatically managed by this class. So, do not set journal_mode using "PRAGMA journal_mode'" statement if your app is using enableWriteAheadLogging()
sql | the SQL statement to be executed. Multiple statements separated by semicolons are not supported. |
---|
SQLException | if the SQL string is invalid |
---|
说明,每次执行SQL只能有一条语句。在执行的时候,不能写成:
- insert into student values('yang','boy');insert into student values('zhou','girl');
形式,而需要将两条SQL语句拆开,每条SQL语句执行一次。
网页题目:Android批量插入数据
标题URL:http://www.shufengxianlan.com/qtweb/news48/430148.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联