Tengo una aplicación que funciona bien en Android 2.1, pero cuando trato de hacer la transición a la 3.0 obtengo un error del cursor que no me resulta familiar.Android 3.0 No se pudo leer la fila #, columna # de la ventana del cursor
java.lang.IllegalStateException: No se pudo leer row0, la columna de -1 ventana del cursor. Asegúrese de que el cursor se inicialice correctamente antes de accediendo a los datos desde él.
Todos los datos se almacenan en una base de datos SQLite y este código funciona bien en Android 2.1. ¿Tiene que inicializarse un cursor de manera diferente en Android 3.0?
A continuación se muestra mi código.
private void OpenGroupData(){
SQLiteDatabase db = openOrCreateDatabase(DATABASE_NAME,Context.MODE_PRIVATE,null);
Cursor cur = db.rawQuery("SELECT groupid FROM properties GROUP BY GroupID" + ";" , null);
LinearLayout glayout = (LinearLayout) findViewById(R.id.Grouplayout);
LinearLayout gwindow = (LinearLayout) findViewById(R.id.groupwindow);
TextView data = new TextView(this);
glayout.addView(data);
data.setText("");
int ID = cur.getColumnIndex("groupid");
int idvalue;
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_USER);
try{
// Check if our result was valid.
cur.moveToFirst();
if (cur != null) {
// Loop through all Results
do {data = new TextView(this);
data.setTextSize(20);
data.setClickable(true);
data.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
GroupClick(v);
}
});
glayout.addView(data);
idvalue = cur.getInt(ID);
data.setId(idvalue);
data.setText("Group: " + idvalue);
}while(cur.moveToNext());
}
cur.close();
db.close();
} catch(Exception e) {
Toast.makeText(getApplicationContext(), "Open Group Exception: " + e.toString(), Toast.LENGTH_SHORT).show();
}
}
Tuve exactamente el mismo problema y esto lo solucionó, ¡gracias! +1 – Matt