android.database.sqlite.SQLiteException : near "0": syntax error: ALTER TABLE data ADD COLUMN 0 INTEGER

标签 android sqlite alter-table

我对数据库很陌生。

我正在尝试向表中添加列,我需要添加名为“0”、“1”、“2”等的列,直到“94169”。

我收到以下错误:

05-04 10:12:50.656: E/An    droidRuntime(2022): FATAL EXCEPTION: main
05-04 10:12:50.656: E/AndroidRuntime(2022): java.lang.RuntimeException: Unable to start     activity ComponentInfo{com.example.koday/com.example.koday.MainActivity}:     android.database.sqlite.SQLiteException: near "0": syntax error: ALTER TABLE data ADD     COLUMN 0 INTEGER
05-04 10:12:50.656: E/AndroidRuntime(2022):     at     android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at     android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at android.os.Handler.dispatchMessage(Handler.java:99)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at android.os.Looper.loop(Looper.java:130)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at android.app.ActivityThread.main(ActivityThread.java:3683)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at java.lang.reflect.Method.invokeNative(Native Method)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at java.lang.reflect.Method.invoke(Method.java:507)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at dalvik.system.NativeStart.main(Native Method)
05-04 10:12:50.656: E/AndroidRuntime(2022): Caused by: android.database.sqlite.SQLiteException: near "0": syntax error: ALTER TABLE data ADD COLUMN 0 INTEGER
05-04 10:12:50.656: E/AndroidRuntime(2022):     at android.database.sqlite.SQLiteDatabase.native_execSQL(Native Method)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1763)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at com.example.koday.DataBaseHelper.aggiungi(DataBaseHelper.java:186)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at com.example.koday.MainActivity.onCreate(MainActivity.java:61)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
05-04 10:12:50.656: E/AndroidRuntime(2022):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
05-04 10:12:50.656: E/AndroidRuntime(2022):     ... 11 more

这是导致错误的代码 fragment :

public void aggiungi() {
    SQLiteDatabase db = this.getWritableDatabase();

    for (int i = 0; i < 94170; i++) {
    db.execSQL("ALTER TABLE data ADD COLUMN " +Integer.toString(i)+" INTEGER"); 
    }
    db.close();
    return;

}

最佳答案

标识符中的合法字符

不带引号的标识符 可以由系统默认字符集 (utf8) 中的任何字母数字字符以及字符“_”和“$”组成。标识符可以以标识符中合法的任何字符开头,包括数字。

但是,标识符不能完全由数字组成,因为那样会使它与数字难以区分。MySQL 对以数字开头的标识符的支持在数据库系统中有些不寻常。如果您使用这样的标识符,如果它包含“E”或“e”,请特别小心,因为这些字符可能导致表达不明确。例如,表达式 23e + 14(“+”号周围有空格)表示第 23e 列加上数字 14,但是 23e+14 呢?是同一个意思,还是科学记数法中的一个数字?您还应该小心使用以 0x 开头的标识符,例如 0x1020,因为它们可能被解释为十六进制常量。

引用: http://www.informit.com/articles/article.aspx?p=377068

请考虑修改您的数据库设计,因为 94170 列超过了允许的最大列数。检查SQLITE Limits

关于android.database.sqlite.SQLiteException : near "0": syntax error: ALTER TABLE data ADD COLUMN 0 INTEGER,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16373257/

相关文章:

ruby-on-rails - rake db :migrate in sqlite3 之后无法查看表

sql-server - 是否可以同时向多个表添加列?

php - 通过 PHP/PDO 使用用户定义的名称和数据类型将 MySQL 列添加/删除到现有表

android - 展示 View NoClassDefFoundError

android - 从移动设备上传照片和视频

java - Android应用程序升级是否调用扩展应用程序的类?

sqlite更改列中每个单元格的日期格式

mysql - SQL 更新表列默认空查询

android - PropertyValuesHolder : Couldn't find setter/getter for property <property-name> with value type float

android - AdMob是为展示还是仅为点击付费?