gpt4 book ai didi

java - Android SQLiteException 语法错误

转载 作者:行者123 更新时间:2023-12-01 14:16:09 26 4
gpt4 key购买 nike

所以我对 SQL 很陌生。我正在尝试将 xml 文件放入我可以搜索的数据库中。我有语法错误,但看不到它/不够熟悉,无法看到它。这是我的 onCreate 方法

 protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
settings = PreferenceManager.getDefaultSharedPreferences(this);
sPreferences = PreferenceManager.getDefaultSharedPreferences(this);
sContext = getApplicationContext();
boolean boot = settings.getBoolean("launch", false);
if (boot == false) {
createData();
}
dataSource = new StopsDataSource(this);
dbhelper = new StopsDBHelper(this,"stops",null,1);
mDatabase = dbhelper.getWritableDatabase();
dataSource.open();
locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
if (locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)){
//Toast.makeText(this, "GPS is Enabled in your devide", Toast.LENGTH_SHORT).show();
}else{
showGPSDisabledAlertToUser();
}
//MyLocationListener = new MyLocationListener();



notificationManager = (NotificationManager)getSystemService(NOTIFICATION_SERVICE);
}

createData()

 private void createDate() {
PullParser parser = new PullParser();
List<Stops> stops = parser.parseXML(this);

for ( Stops stop: stops) {
dataSource.create(stop);
}
}

和 DBHelper

public class StopsDBHelper extends SQLiteOpenHelper {

public static final String TABLE_STOPS = "stops";
public static final String COlUMN_ID = "stopID";
public static final String COLUMN_STOP_NAME = "stopName";
public static final String COLUMN_STOP_LAT = "stopLat";
public static final String COLUMN_STOP_LON = "stopLon";
public static final String TABLE_CREATE = "CREATE TABLE" + TABLE_STOPS + "(" + COlUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COlUMN_ID + " TEXT, " + COLUMN_STOP_LAT + " TEXT, "
+ COLUMN_STOP_LON + " TEXT, " + COLUMN_STOP_NAME + " TEXT" + ")";
public StopsDBHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
}

@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
sqLiteDatabase.execSQL(TABLE_CREATE);
}

@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i2) {
sqLiteDatabase.execSQL("DROP TABLE IF EXISTS " + TABLE_STOPS);
onCreate(sqLiteDatabase);
}

}

我收到的错误是

   08-06 19:21:06.041    5784-5784/ccalgary.transit.helper E/AndroidRuntime: FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to start activity ComponentInfo{ccalgary.transit.helper/ccalgary.transit.helper.MainActivity}: android.database.sqlite.SQLiteException: near "TABLEstops": syntax error (code 1): , while compiling: CREATE TABLEstops(stopID INTEGER PRIMARY KEY AUTOINCREMENT, stopID TEXT, stopLat TEXT, stopLon TEXT, stopName TEXT)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2306)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2356)
at android.app.ActivityThread.access$600(ActivityThread.java:150)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1244)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5195)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)
at dalvik.system.NativeStart.main(Native Method)
Caused by: android.database.sqlite.SQLiteException: near "TABLEstops": syntax error (code 1): , while compiling: CREATE TABLEstops(stopID INTEGER PRIMARY KEY AUTOINCREMENT, stopID TEXT, stopLat TEXT, stopLon TEXT, stopName TEXT)
at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method)
at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:882)
at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:493)
at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588)
at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58)
at android.database.sqlite.SQLiteStatement.<init>(SQLiteStatement.java:31)
at android.database.sqlite.SQLiteDatabase.executeSql(SQLiteDatabase.java:1663)
at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1594)
at ccalgary.transit.helper.StopsDBHelper.onCreate(StopsDBHelper.java:25)
at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:252)
at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:164)
at ccalgary.transit.helper.MainActivity.onCreate(MainActivity.java:75)
at android.app.Activity.performCreate(Activity.java:5104)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2260)
... 11 more

它的 TABLE_CREATE 有问题,我看不出有什么明显的问题。有什么建议么?提前致谢。

最佳答案

是的,这里确实有语法错误。更改此行

public static final String TABLE_CREATE = "CREATE TABLE" + TABLE_STOPS + "(" + COlUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +  COlUMN_ID + " TEXT, " + COLUMN_STOP_LAT + " TEXT, "
+ COLUMN_STOP_LON + " TEXT, " + COLUMN_STOP_NAME + " TEXT" + ")";

对此:

public static final String TABLE_CREATE = "CREATE TABLE " + TABLE_STOPS + "(" + COlUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +  COlUMN_ID + " TEXT, " + COLUMN_STOP_LAT + " TEXT, "
+ COLUMN_STOP_LON + " TEXT, " + COLUMN_STOP_NAME + " TEXT" + ")";

您只是在查询中的 TABLE 和 TableName 之间缺少一个空格

关于java - Android SQLiteException 语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18093256/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com