编译sqlite时出现语法错误

时间:2013-08-23 14:38:06

标签: android sqlite compiler-errors

我正在尝试使用sqlite为我的数据库创建一个新表:

String CREATE_ARCHIVE_TABLE = 
"CREATE TABLE {0} ({1} INTEGER PRIMARY KEY AUTOINCREMENT," +
" {2} TEXT NOT NULL, {3} TEXT NOT NULL, {4} TEXT NOT NULL, {5} INTEGER);";

db.execSQL(MessageFormat.format(CREATE_ARCHIVE_TABLE,AItext.TABLE_NAME,AItext._ID,
        AItext.TITLE,AItext.MESSAGE,AItext.DATE,AItext.TYPE));

使用界面:

public interface AItext extends BaseColumns {
  String TABLE_NAME = "table_name";
  String TITLE = "title";
  String MESSAGE = "message";
  String DATE = "date";
  String TYPE = "type";
  String[] COLUMNS = new String[]
  { _ID, TITLE, MESSAGE, DATE, TYPE };
}

但我有以下异常,我看不到错误

android.database.sqlite.SQLiteException: near "INTEGER": syntax error: , 
while compiling: CREATE TABLE archive_contacts_name (_id INTEGER PRIMARY KEY
AUTOINCREMENT, message INTEGER, name TEXT NOT NULL, phone TEXT NOT NULL,
check INTEGER, note TEXT NOT NULL);

1 个答案:

答案 0 :(得分:1)

正如@aim所说,CHECK实际上是一个不能用作列名的SQLite关键字。

  

CHECK约束可以附加到列定义或指定为表约束。在实践中它没有任何区别。每次向表中插入新行或更新现有行时,将评估与每个CHECK约束关联的表达式,并以与CAST表达式相同的方式强制转换为NUMERIC值。如果结果为零(整数值0或实际值0.0),则发生约束违规。如果CHECK表达式的计算结果为NULL或任何其他非零值,则它不是约束违例。 CHECK约束的表达式可能不包含子查询。

     

从版本3.3.0开始支持CHECK约束。在版本3.3.0之前,CHECK约束已解析但未强制执行。