2015-11-30 1 views
0

J'ai essayé de référencer l'ancien code pour créer une table. J'ai changé les noms de clé/colonne pour la nouvelle table et tout fonctionnait bien. Cependant, quand j'ai essayé de changer le nom de "dépenses" (de l'ancien code) à "transaction" (nouveau code). Je suisAndroid SQL Lite aide: création de la base de données

E/SQLiteLog: (1) near "transaction": syntax error 
D/AndroidRuntime: Shutting down VM 
E/AndroidRuntime: FATAL EXCEPTION: main 
    Process: com.cs465.groceryrun.groceryrun, PID: 7199 
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.cs465.groceryrun.groceryrun/com.cs465.groceryrun.groceryrun.Transactions}: android.database.sqlite.SQLiteException: near "transaction": syntax error (code 1): , while compiling: CREATE TABLE transaction (_id INTEGER PRIMARY KEY,title TEXT,person TEXT,role TEXT,date TEXT,due_date TEXT,status TEXT,rating REAL,amount REAL); 

Tout ce que je ne faisais que changer le TABLE_NAME de:

public static abstract class TransactionTable implements BaseColumns { 

    public static final String TABLE_NAME = "expense"; 
    public static final String COLUMN_NAME_TITLE = "title"; 
    public static final String COLUMN_NAME_PERSON = "person"; 
    public static final String COLUMN_NAME_ROLE = "role"; 
    public static final String COLUMN_NAME_DATE = "date"; 
    public static final String COLUMN_NAME_DUE_DATE = "due_date"; 
    public static final String COLUMN_NAME_STATUS = "status"; 
    public static final String COLUMN_NAME_RATING = "rating"; 
    public static final String COLUMN_NAME_AMOUNT = "amount"; 

    public static final String CREATE_TABLE = "CREATE TABLE " + TABLE_NAME + " (" + 
      _ID + " INTEGER PRIMARY KEY," + 
      COLUMN_NAME_TITLE + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_PERSON + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_ROLE + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_DATE + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_DUE_DATE + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_STATUS + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_RATING + REAL_TYPE + COMMA_SEP + 
      COLUMN_NAME_AMOUNT + REAL_TYPE + ");"; 

    public static final String DELETE_TABLE = "DROP TABLE IF EXISTS " + TABLE_NAME; 
} 

à:

public static abstract class TransactionTable implements BaseColumns { 

    public static final String TABLE_NAME = "transaction"; //????? 
    public static final String COLUMN_NAME_TITLE = "title"; 
    public static final String COLUMN_NAME_PERSON = "person"; 
    public static final String COLUMN_NAME_ROLE = "role"; 
    public static final String COLUMN_NAME_DATE = "date"; 
    public static final String COLUMN_NAME_DUE_DATE = "due_date"; 
    public static final String COLUMN_NAME_STATUS = "status"; 
    public static final String COLUMN_NAME_RATING = "rating"; 
    public static final String COLUMN_NAME_AMOUNT = "amount"; 

    public static final String CREATE_TABLE = "CREATE TABLE " + TABLE_NAME + " (" + 
      _ID + " INTEGER PRIMARY KEY," + 
      COLUMN_NAME_TITLE + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_PERSON + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_ROLE + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_DATE + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_DUE_DATE + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_STATUS + TEXT_TYPE + COMMA_SEP + 
      COLUMN_NAME_RATING + REAL_TYPE + COMMA_SEP + 
      COLUMN_NAME_AMOUNT + REAL_TYPE + ");"; 

    public static final String DELETE_TABLE = "DROP TABLE IF EXISTS " + TABLE_NAME; 
} 

Est-ce que quelqu'un sait pourquoi cela se passe?

Répondre