Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sqlite/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
dataAdapter sqlite android上的null_Android_Sqlite - Fatal编程技术网

dataAdapter sqlite android上的null

dataAdapter sqlite android上的null,android,sqlite,Android,Sqlite,我试图在android上从我的sqlite数据库加载值,但在dataAdapter上不断得到null。我使用此方法在代码中的许多地方加载值。但在这里,我一直得到零,我不知道为什么。希望你能帮助我的人。我确信这是一个小错误,但已经过去几天了,我似乎找不到它。我在dataAdapter1变量的最后几行得到null错误。我放星星的地方 我的数据库是: public long insertDefaultDistanceUnit(String dUnit, int usedBoolean) { C

我试图在android上从我的sqlite数据库加载值,但在dataAdapter上不断得到null。我使用此方法在代码中的许多地方加载值。但在这里,我一直得到零,我不知道为什么。希望你能帮助我的人。我确信这是一个小错误,但已经过去几天了,我似乎找不到它。我在dataAdapter1变量的最后几行得到null错误。我放星星的地方

我的数据库是:

public long insertDefaultDistanceUnit(String dUnit, int usedBoolean) {
    ContentValues initialValues = new ContentValues();
    initialValues.put(MY_CURRENT_DISTANCE, dUnit);
    initialValues.put(MY_CURRENT_DISTANCE_BOOLEAN, usedBoolean);
    return db.insert(MY_CURRENT_DISTANCE_UNIT_TABLE, null, initialValues);
}

public Cursor getAllDistanceUnits() {
    return db.query(MY_CURRENT_DISTANCE_UNIT_TABLE,
            new String[] { MY_CURRENT_DISTANCE }, null, null, null, null,
            null);
}

public Cursor getCurrentDistanceUnit() throws SQLException {
    Cursor mCursor = db.query(true, MY_CURRENT_DISTANCE_UNIT_TABLE,
            new String[] { MY_CURRENT_DISTANCE },
            MY_CURRENT_DISTANCE_BOOLEAN + "='1'", null, null, null, null,
            null);
    if (mCursor != null) {
        mCursor.moveToFirst();
    }
    return mCursor;
}
在打开要加载值的类之前,将值放入表中的我的设置类:

    db.open();
    Cursor c2 = db.getAllDistanceUnits();
    distanceList = new ArrayList<String>();
    if (c2.moveToFirst()) {
        do {
            distanceList.add(c2.getString(c2
                    .getColumnIndex(DBAdapter.MY_CURRENT_DISTANCE)));
        } while (c2.moveToNext());
    }
    if (distanceList.size() > 0) {
        distanecExist = 1;
    }
    db.close();

    if (distanecExist == 0) {
        currentDistanceUnit = new ArrayList<String>();
        currentDistanceUnit.add("km" + " Kilometers");
        currentDistanceUnit.add("m" + " Miles");
        db.open();
        for (int i = 0; i <= currentDistanceUnit.size() - 1; i++) {
            if (i == 0) {
                db.insertDefaultDistanceUnit(currentDistanceUnit.get(i)
                        .toString(), 1);
            } else {
                db.insertDefaultDistanceUnit(currentDistanceUnit.get(i)
                        .toString(), 0);
            }
        }
        db.close();
    }
    currentDistance = (TextView) findViewById(R.id.currentDistance);
    distanceSpinner = (Spinner) findViewById(R.id.distanceSpinner);
    setNewDistanceButton = (Button) findViewById(R.id.setNewDistanceButton);

    db.open();
    Cursor c2 = db.getCurrentDistanceUnit();
    currentDistanceList2 = new ArrayList<String>();
    String distanceUnit = "";
    if (c2.getCount() == 1) {
        distanceUnit = c2.getString(c2
                .getColumnIndex(DBAdapter.MY_CURRENT_DISTANCE));
    }
    currentDistance.setText(distanceUnit);
    db.close();

    db.open();
    Cursor c1 = db.getAllDistanceUnits();
    currentDistanceList = new ArrayList<String>();
    if (c1.moveToFirst()) {
        do {
            currentDistanceList.add(c1.getString(c1
                    .getColumnIndex(DBAdapter.MY_CURRENT_DISTANCE)));
        } while (c1.moveToNext());
    }
    db.close();
    dataAdapter1 = new ArrayAdapter<String>(this,
            android.R.layout.simple_spinner_item, currentDistanceList);
    dataAdapter1
            .setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
    distanceSpinner.setAdapter(**dataAdapter1**);
    distanceSpinner.setSelection(0);
如果我们尝试设置适配器(null),则不会出现崩溃和null指针异常。 如果你的坠机是在线的

distanceSpinner.setAdapter(**dataAdapter1**);

distanceSpinner为空,不是您的dataAdapter。

您可以发布stacktrace吗?true。忘了吧。其posted检查您的ArrayAdapter上下文并检查将数据添加到arraylist currentDistanceList的位置。添加并确保您的arraylist不为null。您在何处声明DataAdapter1是全局变量。我没有在这里提到它,我更改了一些代码的顺序,现在错误指向这一行currentDistance.setText(distanceUnit);在将文本设置为distance unit之前,我在日志中打印,并且有一个值init。但当我将文本设置为当前距离时,我总是得到空值。我的当前距离声明正确。既然distanceUnit有值,为什么我会得到null?它不是distanceUnit,罪魁祸首是currentDistance。这是类似的错误。检查用于setContentView的布局。它是否有ID currentDistance、distanceSpinner等。你说得对。问题出在setContentView中。这和它应该有的略有不同,它造成了所有这些麻烦。非常感谢。
distanceSpinner.setAdapter(**dataAdapter1**);