2013-05-04 110 views
1

我对数据库非常陌生。android.database.sqlite.SQLiteException:接近“0”:语法错误:ALTER TABLE数据ADD COLUMN 0 INTEGER

我想添加列到一个表中,我需要添加名为“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 

这是代码导致错误的片段:在标识符

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; 

} 
+1

为什么你要在你的桌子上增加94列? – tolgap 2013-05-04 10:32:17

+1

@tolgap确实不好的主意,此外94000超过允许的最大列数:-) – 2013-05-04 10:51:49

回答

4

合法字符

未加引号的标识符能由系统默认字符集中的任何字母数字字符组成(utf8),加上字符'_'和'$'。标识符可以以任何在标识符中合法的字符开头,包括数字。

但是,标识符不能完全由数字组成,因为这会使其与数字无法区分。 MySQL对数字开头的标识符的支持在数据库系统中有些不寻常。如果您使用这样的标识符,如果它包含'E'或'e',请特别小心,因为这些字符可能会导致模糊的表达。例如,表达式23e + 14(围绕'+'符号的空格)意味着列23e加上数字14,但是23e + 14怎么办?这是否意味着相同的事情,还是科学记数法中的数字?您还应该小心使用以0x开头的标识符(如0x1020),因为它们可能被解释为十六进制常量。

参考:http://www.informit.com/articles/article.aspx?p=377068

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

+1

如果是报价,请将其作为报价。否则,你是对的。 – 2013-05-04 10:34:31

相关问题