1

JSON 配列を使用して WebSQL データベースにデータを入力しようとしています (オブジェクトはmyJSONObject、配列は と呼ばれcostcodesます)。

関数はクリックで実行され、データベースは正常に作成されますが、データはデータベースに挿入されません。スローもエラーも発生せず、何もしません。

私の最初の考えは、データが適切にエスケープされていないということでしたが、どこでどのようにエスケープするのか正確にはわかりません。だから私は困惑しています。

    localDB = null;

    function initDB()
    {
        if (localDB==null)
        {
            var shortName = 'Costcode';
            var version = '1.0';
            var displayName = 'Costcode';
            var maxSize = 217802; // in bytes
            localDB = window.openDatabase(shortName, version, displayName, maxSize);
        }

    }
            function buildTable()
    {
       var sQuery = 'CREATE TABLE IF NOT EXISTS Costcode ('+
                    'id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,' +
                    'cost_code_no VARCHAR NULL,' +
                    'row_unique_no VARCHAR NULL,' +
                    'cost_class_no VARCHAR NULL,' +
                    'Table_Version VARCHAR DEFAULT "1.0");';
        try
        {
            initDB();
            localDB.transaction(function(transaction)
            {
                transaction.executeSql(sQuery, []);
                console.log('sucess');
            });
        }
        catch (e)
        {
           alert("Error: Unable to create table 'x" + "' " + e + ".");
           return;
       }    
    }


 function exeSQLFast()
    {

                initDB();
                localDB.transaction(function(transaction)
                {
                    for (var x = 0; x <myJSONObject.costcodes.length; x++)
                    {

                        var costcodeno = myJSONObject.costcodes[x].cost_code_no;
                        var rowuniqueid = myJSONObject.costcodes[x].row_unique_id;
                        var costclassno = myJSONObject.costcodes[x].cost_class_no;
                        console.log(costcodeno);
                        console.log(rowuniqueid); 
                        console.log(costclassno);
                    transaction.executeSql('INSERT INTO Costcode (cost_code_no, row_unique_id, cost_class_no) VALUES (? , ? , ?)',
                     [costcodeno,
                     rowuniqueid,
                     costclassno]
                     , function(transaction, results)
                        {
                            console.log(costcodeno);
                            console.log('hooray');
                        }

                    )};
                    }
            )}

</script>
</head>

<body onLoad="buildTable();">
<input type="button" onClick="exeSQLFast();" value='button'>
</body>
</html>

コンソール ログは、変数がすべて適切に定義されていることを示していますが、insert ステートメントは実行されていません。何か案は?

ここに例がありますmyJSONObject.costcodes[2]

cost_class_no: "    3"
cost_code_no: "      1000"
row_unique_id: 335

それは問題のように見えますね...

4

1 に答える 1

0

問題は、挿入ステートメントでrow_unique_no列row_unique_idを呼び出したことです。今、私は愚かだと感じています。

しかし、WebSQL データベースに適切にデータを入力する方法に興味がある場合は、次のようにします。列名を間違って入力しないでください。

于 2013-02-27T19:08:13.093 に答える