SQLite insert No hay error de columna en android

Tengo problema al insertar datos de CSV. La pieza CSV funciona, pero la inserción devuelve el siguiente error. Básicamente dice que no existe la columna. Debajo está el código y también el código de la base de datos.

09-06 17:52:22.725: E/AndroidRuntime(19168): FATAL EXCEPTION: main 09-06 17:52:22.725: E/AndroidRuntime(19168): android.database.sqlite. SQLiteException: no such column: Ananas (code 1): , while compiling: INSERT INTO food (name, sacharides, glycemia, category1) VALUES (Ananas, 13, 45,1) 09-06 17:52:22.725: E/AndroidRuntime(19168): at android.database.sqlite.SQLiteConnection.nativePrepareStatement (Native Method) 

Aquí está el código que falla.

  FoodDatabase myHelper = new FoodDatabase(getApplicationContext()); myDatabase = myHelper.getReadableDatabase(); String[] nextLine; try { while ((nextLine = reader.readNext()) != null) { // nextLine[] is an array of values from the line System.out.println(nextLine[0]+ " " + nextLine[1] +" "+ nextLine[2]); String sql = "INSERT INTO food (name, sacharides, glycemia, category1) " + "VALUES (" + nextLine[0] + ", " + nextLine[1] + ", " + nextLine[2]+ "," + nextLine[3] +")"; // myDatabase.rawQuery(sql, null); myDatabase.execSQL(sql); } } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } 

Aquí va cómo se ve la base de datos.

 public class FoodDatabase extends SQLiteOpenHelper { public static final String TABLE_FOOD = "food"; public static final String COLUMN_ID = "id"; public static final String COLUMN_NAME = "name"; public static final String COLUMN_SACHARIDES = "sacharides"; public static final String COLUMN_SACHARIDESPORTION = "sacharides_per_portion"; public static final String COLUMN_PORTIONSIZE = "portion_size"; public static final String COLUMN_GLYCEMIA = "glycemia"; public static final String COLUMN_CATEGORY1 = "category1"; public static final String COLUMN_CATEGORY2 = "category2"; public static final String COLUMN_CATEGORY3 = "category3"; private static final String DATABASE_NAME = "tables.db"; private static final int DATABASE_VERSION = 1; // Database creation sql statement private static final String DATABASE_CREATE = "create table " + TABLE_FOOD + "(" + COLUMN_ID + " integer primary key autoincrement, " + COLUMN_NAME + " text," + COLUMN_SACHARIDES + " real," + COLUMN_PORTIONSIZE + " integer," + COLUMN_SACHARIDESPORTION + " real," + COLUMN_GLYCEMIA + " integer,"+ COLUMN_CATEGORY1 + " integer," +COLUMN_CATEGORY2 + " integer," +COLUMN_CATEGORY3 + " integer);"; public FoodDatabase(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase database) { database.execSQL(DATABASE_CREATE); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { Log.w(FoodDatabase.class.getName(), "Upgrading database from version " + oldVersion + " to " + newVersion + ", which will destroy all old data"); db.execSQL("DROP TABLE IF EXISTS " + TABLE_FOOD); onCreate(db); } 

No estoy seguro, pero es posible que necesite tener comillas simples '' alrededor de las cadenas dentro de VALUES . Tratar:

 String sql = "INSERT INTO food (name, sacharides, glycemia, category1) " + "VALUES ('" + nextLine[0] + "', '" + nextLine[1] + "', '" + nextLine[2]+ "', '" + nextLine[3] +"' )"; 

En mi caso,

Desafortunadamente el nombre de la tabla es incompatible. Descansar Y sigue!

  • Carácter turco en SQLite mientras utiliza la expresión LIKE
  • ¿Cómo puedo borrar una base de datos SQLite cada vez que inicie mi aplicación?
  • Devolver todas las columnas de una tabla SQLite en Android
  • Uso correcto de Sqlite en Android (SQLiteOpenHelper, conexiones, hilo principal, etc ...)
  • ¿Cómo establecer el tipo de datos en SQLiteDatabase vinculación de consulta en bruto?
  • SQLiteDatabase.openDatabase vs SQLiteOpenHelper.getReadableDatabase
  • Cómo eliminar una fila de una tabla en SQLite android?
  • Desempeño de Android: Archivo plano vs SQLite
  • Uso de la memoria sqlite android
  • Android SQLiteException: Error al cambiar la configuración regional de db a 'en_US'
  • ¿Por qué un delete rawQuery necesita un moveToFirst para eliminar realmente las filas?
  • FlipAndroid es un fan de Google para Android, Todo sobre Android Phones, Android Wear, Android Dev y Aplicaciones para Android Aplicaciones.