Application se bloque au Démarrage en Raison De java.lang.IllegalArgumentException: la colonne " _id " n'existe pas
Chaque fois que je démarre mon application, j'obtiens un java.lang.IllegalArgumentException: column '_id' does not exist
erreur dans mon LogCat. J'ai créé la colonne '_id'
, mais ça en jette toujours présent. Voici ma main .java:
package com.gantt.shoppinglist;
import android.app.Dialog;
import android.app.ListActivity;
import android.database.Cursor;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
public class ShoppingList extends ListActivity {
private DataHelper DataHelper;
/** Called when the activity is first created. */
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
DataHelper = new DataHelper(this);
Cursor c = (Cursor) DataHelper.selectAll();
long id = c.getLong(c.getColumnIndex("_id"));
startManagingCursor(c);
ListView lv = (ListView) findViewById(android.R.id.list);
String[] from = new String[] { com.gantt.shoppinglist.DataHelper.getDatabaseName() };
int[] to = new int[] { android.R.id.text1 };
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this,
android.R.layout.simple_list_item_1, c, from, to);
lv.setAdapter(adapter);
Button button1main = (Button) findViewById(R.id.add);
button1main.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
final Dialog additem = new Dialog(ShoppingList.this);
additem.setContentView(R.layout.maindialog);
final EditText et = (EditText)additem.findViewById(R.id.edittext);
additem.setTitle("Type your item");
additem.setCancelable(true);
et.setHint("Type the name of an item...");
Button button = (Button) additem.findViewById(R.id.cancel);
button.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
additem.dismiss();
}
});
additem.show();
Button ok = (Button) additem.findViewById(R.id.ok);
ok.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
final String text = et.getText().toString();
additem.dismiss();
et.setText("");
}
});
}
});
}
}
Voici mon DataHelper classe:
package com.gantt.shoppinglist;
import java.util.ArrayList;
import java.util.List;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteStatement;
import android.util.Log;
public class DataHelper {
private static final String DATABASE_NAME = "items.db";
private static final int DATABASE_VERSION = 1;
private static final String TABLE_NAME = "table1";
public static final String KEY_ROWID = "_id";
private Context context;
private SQLiteDatabase db;
private SQLiteStatement insertStmt;
private static final String INSERT = "insert into "
+ TABLE_NAME + "(name) values (?)";
public DataHelper(Context context) {
this.context = context;
OpenHelper openHelper = new OpenHelper(this.context);
this.db = openHelper.getWritableDatabase();
this.insertStmt = this.db.compileStatement(INSERT);
}
public long insert(String name) {
this.insertStmt.bindString(1, name);
return this.insertStmt.executeInsert();
}
public void deleteAll() {
this.db.delete(TABLE_NAME, null, null);
}
public Cursor selectAll() {
List<String> list = new ArrayList<String>();
Cursor cursor = this.db.query(TABLE_NAME, new String[] { "name" },
null, null, null, null, "name desc");
if (cursor.moveToFirst()) {
do {
list.add(cursor.getString(0));
} while (cursor.moveToNext());
}
if (cursor != null && !cursor.isClosed()) {
cursor.close();
}
return cursor;
}
public static String getDatabaseName() {
return DATABASE_NAME;
}
private static class OpenHelper extends SQLiteOpenHelper {
OpenHelper(Context context) {
super(context, getDatabaseName(), null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("CREATE TABLE " + TABLE_NAME + "(id INTEGER PRIMARY KEY, name TEXT");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
Log.w("Example", "Upgrading database, this will drop tables and recreate.");
db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
onCreate(db);
}
}
}
- avez-vous assurez-vous de désinstaller l'application et de ré-installer de manière à ce que votre base de données nouvellement créée, _id de la colonne? ou peut-être l'inclure onUpgrade méthode?
Vous devez vous connecter pour publier un commentaire.
J'ai eu un problème similaire, je pense que c'est un cas d'avoir à "sélectionner" (ou "sélectionner comme") quelque chose qui s'appelle
_id
parce que leSimpleCursorAdapter
besoin.De la la documentation:
Dans mon cas, j'ai un numéroauto colonne dans ma table appelée " oid, et j'ai donc modifié ma commande SELECT (par exemple)...
Ce réglé le problème pour moi.
MODIFIER pour afficher plus vaste de code...
De messagerie unifiée ne sais pas si vous avez juste collé dans le mal, mais:
est faux. Vous avez besoin de la déclarer un objet et l'appel de vos méthodes sur l'initialisation de la Base de données de l'objet:
Oh my bad tu viens de déclarer votre nom de variable avec un D Majuscule , ce n'est pas recommandé ni java standard de style de codage.
http://java.about.com/od/javasyntax/a/nameconventions.htm