Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/206.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
android.database.sqlite.SQLiteException:near";0";:语法错误:ALTER TABLE data ADD列0 INTEGER_Android_Sqlite_Alter Table - Fatal编程技术网

android.database.sqlite.SQLiteException:near";0";:语法错误:ALTER TABLE data ADD列0 INTEGER

android.database.sqlite.SQLiteException:near";0";:语法错误:ALTER TABLE data ADD列0 INTEGER,android,sqlite,alter-table,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{co

我对数据库很陌生

我正在尝试向表中添加列,我需要添加名为“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;

}
public void aggiungi(){
SQLiteDatabase db=this.getWritableDatabase();
对于(int i=0;i<94170;i++){
execSQL(“altertabledataaddcolumn”+Integer.toString(i)+“Integer”);
}
db.close();
返回;
}

标识符中的合法字符

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

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

参考资料:


请考虑修改数据库设计,因为94170列超过了允许列的最大数量。检查标识符中的合法字符

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

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

参考资料:


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

你到底为什么要在表中添加94000列?@tolgap确实是个坏主意,而且94000列超出了允许的最大列数:-)你到底为什么要在表中添加94000列?@tolgap确实是个坏主意,而且94000列超出了允许的最大列数:-)