How to insert multiple rows in Web SQL Database?
Asked Answered
D

1

7

I have a JavaScript object with multiple rows of data and I want to insert it into web sql database. Here is how my code looks like.

for(i in rows)
{
    (function(row){
        db.transaction(function(tx) {
            tx.executeSql("INSERT INTO my_table (id, name, parent_id) VALUES (?, ?, ?)",
                [ row.id, row.name, row.parent_id ], onSuccess, onError
            );
        });
    })(rows[i]);
}

My questions about this are:

  1. This can be done by moving outer loop inside db.transaction. Will it be better and why?
  2. Is it possible to add multiple rows in single query like multiple values in single MySQL INSERT? Or I should not worry about this.
Disconnect answered 14/11, 2012 at 19:46 Comment(3)
purely sql options: blog.sqlauthority.com/2012/08/29/…Smokeproof
#453359Smokeproof
possible duplicate of Web SQL insert data into multiple rowsSamantha
H
3

This can be done by moving outer loop inside db.transaction. Will it be better and why?

yes. much better. 1) creating a transaction is not cheap. 2) looping async is generally bad .

Is it possible to add multiple rows in single query like multiple values in single MySQL INSERT? Or I should not worry about this.

don't worry. Multiple rows workaround are syntactic sugar. No performance benefit. Better loop it under one transaction.

Again do not loop executeSql, it is async.

Hudis answered 15/11, 2012 at 1:59 Comment(1)
I am facing problem in this that when i insert multiple rows in db.transaction function than it only inserting last row multiple times. I agree with you that due to async it is performing this king of behavior,can you please let me know what would be the solution and if you can give any sample than it will help me out in better way.Sugihara

© 2022 - 2024 — McMap. All rights reserved.