2012-07-04 64 views
5

我試圖以檢索來自Android的SQLite數據庫的數據,但它的givine例外選取名稱,沒有這樣的列: android.database.sqlite.SQLiteException:沒有這樣的列:AA:,在編譯:從猛男所在地址= AA


sqlite的選擇查詢是 - :

c=db.rawQuery("Select Name from stud Where Address="+a,null); 


例外: -

07-04 18:07:00.888: I/Database(648): sqlite returned: error code = 1, msg = no such column: aa 
07-04 18:07:00.910: D/AndroidRuntime(648): Shutting down VM 
07-04 18:07:00.910: W/dalvikvm(648): threadid=1: thread exiting with uncaught exception (group=0x40015560) 
07-04 18:07:00.948: E/AndroidRuntime(648): FATAL EXCEPTION: main 
07-04 18:07:00.948: E/AndroidRuntime(648): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.my.StudentInfoManagement/com.my.StudentInfoManagement.ListData}: android.database.sqlite.SQLiteException: no such column: aa: , while compiling: Select Name from stud Where Address=aa 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.os.Handler.dispatchMessage(Handler.java:99) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.os.Looper.loop(Looper.java:123) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.app.ActivityThread.main(ActivityThread.java:3683) 
07-04 18:07:00.948: E/AndroidRuntime(648): at java.lang.reflect.Method.invokeNative(Native Method) 
07-04 18:07:00.948: E/AndroidRuntime(648): at java.lang.reflect.Method.invoke(Method.java:507) 
07-04 18:07:00.948: E/AndroidRuntime(648): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
07-04 18:07:00.948: E/AndroidRuntime(648): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
07-04 18:07:00.948: E/AndroidRuntime(648): at dalvik.system.NativeStart.main(Native Method) 
07-04 18:07:00.948: E/AndroidRuntime(648): Caused by: android.database.sqlite.SQLiteException: no such column: aa: , while compiling: Select Name from stud Where Address=aa 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.database.sqlite.SQLiteCompiledSql.native_compile(Native Method) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.database.sqlite.SQLiteCompiledSql.compile(SQLiteCompiledSql.java:92) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.database.sqlite.SQLiteCompiledSql.<init>(SQLiteCompiledSql.java:65) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:83) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.database.sqlite.SQLiteQuery.<init>(SQLiteQuery.java:49) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:42) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1356) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.database.sqlite.SQLiteDatabase.rawQuery(SQLiteDatabase.java:1324) 
07-04 18:07:00.948: E/AndroidRuntime(648): at com.my.StudentInfoManagement.DataHelper.show(DataHelper.java:86) 
07-04 18:07:00.948: E/AndroidRuntime(648): at com.my.StudentInfoManagement.ListData.onCreate(ListData.java:19) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
07-04 18:07:00.948: E/AndroidRuntime(648): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 
07-04 18:07:00.948: E/AndroidRuntime(648): ... 11 more 
07-04 18:07:03.140: I/Process(648): Sending signal. PID: 648 SIG: 9 

回答

13

這只是因爲你的sql查詢是錯誤的。查詢文本時,需要在查詢字符串周圍添加單引號。

你行應爲:

c=db.rawQuery("Select Name from stud Where Address='"+a+"'",null); 
+0

問題是在地址!這是SQL中的內置函數,它不能是列名! –

+0

對不起,我認爲你錯了。地址從來沒有,也不會在任何SQL實現中成爲保留字。使用SQL最基本的用例是存儲人員及其地址。將ADDRESS作爲保留字是非常愚蠢的。 – Yahel

+0

我剛剛測試過這個,當我在SQL查詢中輸入地址時,它是藍色的,那麼爲什麼它是藍色的,如果它不是保留字?! –

0

如果您正在使用string那麼你必須表達它在單引號,如:

Cursor cursor = db.rawQuery("SELECT '"+WINNER+"' FROM '"+TABLE.trim()+"' WHERE 
     country1='"+c1.trim()+"' AND Country2='"+c2.trim()+"'", null); 

如果您是代表一個int值 那麼你就可以簡單地使用像這樣:+num+

相關問題