Volley将数据随机加载到sqlite

时间:2016-02-17 20:10:06

标签: android json sqlite

我使用VolleyJSON字符串加载到SQLite,但我遇到Volley填充SQLite字段的问题随机地,一次一个字段与JSON在第二次相同的字段为空时。

我正在考虑实施进度对话框,也许UI主题可以停止Volley,但我不确定......

我的方法:

private void loadJsonToSQLite() {
    RequestQueue queue = Volley.newRequestQueue(this);
    mDB = this.openOrCreateDatabase(Constants.DATABASE_NAME, MODE_PRIVATE, null);


    for (int i = 0; i < routeArray.length; i++) {

        if (!mDB.isOpen()) {
            mDB = getApplicationContext().openOrCreateDatabase(Constants.DATABASE_NAME, MODE_PRIVATE, null);
        }

        final String urlPart = routeArray[i];
        final String urlPartReverse = routeArrayReverse[i];
        final String tableName = "[" + urlPart + "]";

        mDB.execSQL("CREATE TABLE " + tableName + " (keyId INTEGER PRIMARY KEY, route TEXT, routeReverse TEXT)");


        StringRequest stringRequest = new StringRequest(Request.Method.GET, url + urlPart,
                new Response.Listener<String>() {
                    @Override

                    public void onResponse(String response) {

                        Matcher m = MY_PATTERN.matcher(response);

                        if (m.find()) {
                            String extracted = m.group(1).trim();
                            ContentValues initialValues = new ContentValues();

                            initialValues.put("keyId", 1);
                            initialValues.put("route", extracted);


                            if (!mDB.isOpen()) {
                                mDB = getApplicationContext().openOrCreateDatabase(Constants.DATABASE_NAME, MODE_PRIVATE, null);

                            }
                            mDB.insert(tableName, null, initialValues);
                        }

                    }
                }, new Response.ErrorListener() {
            @Override
            public void onErrorResponse(VolleyError error) {
            }
        });

        queue.add(stringRequest);
        mDB.close();


        StringRequest stringRequestReverse = new StringRequest(Request.Method.GET, url + urlPartReverse,
                new Response.Listener<String>() {
                    @Override

                    public void onResponse(String response) {

                        Matcher m = MY_PATTERN.matcher(response);

                        if (m.find()) {
                            String extracted = m.group(1).trim();
                            ContentValues initialValues = new ContentValues();

                            initialValues.put("routeReverse", extracted);


                            if (!mDB.isOpen()) {
                                mDB = getApplicationContext().openOrCreateDatabase(Constants.DATABASE_NAME, MODE_PRIVATE, null);

                            }
                            mDB.update(tableName,initialValues,null,null);
                        }

                    }
                }, new Response.ErrorListener() {
            @Override
            public void onErrorResponse(VolleyError error) {

            }
        });
        queue.add(stringRequestReverse);
        mDB.close();

    }


}

也许我在Volley处错了?

我在不同的链接中有JSON个字符串 - 因为我使用了循环。

1 个答案:

答案 0 :(得分:0)

自己解决,只需添加第二个循环,因为我知道2 Volley个请求可以存在于一个循环中