【问题标题】:Android SQL Lite help: creating databasetableAndroid SQLite 帮助:创建数据库表
【发布时间】:2015-11-30 18:49:51
【问题描述】:

我一直在尝试引用旧代码来创建表格。我更改了新表的键/列名称,一切正常。但是,当我尝试将名称从“费用”(旧代码)更改为“交易”(新代码)时。我得到了

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);

我所做的只是将 TABLE_NAME 更改为:

 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;
}

有人知道为什么会这样吗?

【问题讨论】:

    标签: android database sqlite contract


    【解决方案1】:

    transaction 是 SQL 中的 reserved keyword。考虑将您的表重命名为例如transactions.

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2014-02-14
      • 2013-04-27
      相关资源
      最近更新 更多