我有一个微调器将数据加载到 sqlite
我在数据库中有字段 ID 和字段名称。
private void loadSpinnerDataHama() {
// database handler
DatabaseSpinner db = new DatabaseSpinner(getApplicationContext());
// Spinner Drop down elements
List<String> lables = db.getAllLabels();
// Creating adapter for spinner
ArrayAdapter<String> dataAdapter = new ArrayAdapter<String>(this,
android.R.layout.simple_spinner_item, lables);
// Drop down layout style - list view with radio button
dataAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
// attaching data adapter to spinner
spin2.setAdapter(dataAdapter);
}
public List<String> getAllLabels(){
List<String> labels = new ArrayList<String>();
// Select All Query
String selectQuery = "SELECT * FROM " + TABLE_LABELS;
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);
// looping through all rows and adding to list
if (cursor.moveToFirst()) {
do {
labels.add(cursor.getString(1));
} while (cursor.moveToNext());
}
// closing connection
cursor.close();
db.close();
// returning lables
return labels;
}
结果是
美国 -> 值为“美国”
法国 -> 值为“法国”
当我将代码更改labels.add(cursor.getString(1));
为labels.add(cursor.getString(0));
结果是
1 -> 值为“1”
2 -> 值为“2”
我尝试使用,int position2 = spin2.getSelectedItemPosition()+1;
但值是微调器的 id/位置,而不是数据库的 id。
如何在微调器上显示字段名称。但值是名称的 id
示例:微调器显示:
美国 -> 值为“1”
法国 -> 值为“2”
BR
亚历克斯