繁体   English   中英

Android SQLite无法识别令牌

[英]Android SQLite unrecognized token

嗨,我在使用SQL数据库时遇到了麻烦,它在我的onCreate()方法中给了我一个错误,我对数据库工作和android编程都比较陌生,所以我真的很困惑。

这是我的代码

@Override
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        db.execSQL("CREATE TABLE " + DATABASE_TABLE1 + " (" + KEY_ROWID
                + " INTEGER PRIMARY KEY AUTOINCREMENT, " + KEY_TITLE
                + " TEXT NOT NULL, " + KEY_PATH + " TEXT NOT NULL, "
                + KEY_TAGS + " TEXT NOT NULL);");
    }

我从logcat得到的错误是这个

E/AndroidRuntime(1537): android.database.sqlite.SQLiteException: unrecognized token: "'s (_id INTEGER PRIMARY KEY AUTOINCREMENT, video_title TEXT NOT NULL, path_in_system TEXT NOT NULL, search_tags TEXT NOT NULL);": , while compiling: CREATE TABLE Video's (_id INTEGER PRIMARY KEY AUTOINCREMENT, video_title TEXT NOT NULL, path_in_system TEXT NOT NULL, search_tags TEXT NOT NULL);

您(通常)不能为表格Video's命名。 也许您只是想使用Videos

但是,如果出于任何原因您绝对需要将该表命名为Video's (带有撇号)或任何其他非标准标识符,则可以使用双引号或方括号。 例如,这确实有效:

db.execSQL("CREATE TABLE [" + DATABASE_TABLE1 + "] (" + KEY_ROWID ...);

就像这样:

db.execSQL("CREATE TABLE \"" + DATABASE_TABLE1 + "\" (" + KEY_ROWID ...);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM