我正在尝试使用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);
答案 0 :(得分:1)
正如@aim所说,CHECK实际上是一个不能用作列名的SQLite关键字。
CHECK约束可以附加到列定义或指定为表约束。在实践中它没有任何区别。每次向表中插入新行或更新现有行时,将评估与每个CHECK约束关联的表达式,并以与CAST表达式相同的方式强制转换为NUMERIC值。如果结果为零(整数值0或实际值0.0),则发生约束违规。如果CHECK表达式的计算结果为NULL或任何其他非零值,则它不是约束违例。 CHECK约束的表达式可能不包含子查询。
从版本3.3.0开始支持CHECK约束。在版本3.3.0之前,CHECK约束已解析但未强制执行。