2016-03-14 3 views
0

вот как я создать таблицу ...Android SQLite java.lang.IllegalArgumentException: колонка «_id» не существует

"CREATE TABLE IF NOT EXISTS Product (
    _ID INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL UNIQUE , 
    Name VARCHAR NOT NULL, 
    Code VARCHAR NOT NULL, 
    Quantity VARCHAR NOT NULL, 
    PRICE DOUBLE NOT NULL);" 

, если я это сделать.

myDb = new DbAdapter(getApplicationContext()); 
     Cursor res = myDb.getData(tbs.productsTable, tbs.getProductsColumns(), " ");  
     toast(res.getColumnName(0)); 

то это показывает _ID, но когда я это сделать:

ListView lvItems = (ListView) findViewById(R.id.listViewProduct); 
     Populate_Products todoAdapter = new Populate_Products(this, res); 
     lvItems.setAdapter(todoAdapter); 

это дает мне эту ошибку:

03-14 19:36:52.459 31990-31990/com.example.danyalahmed.stockmanagement E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.danyalahmed.stockmanagement, PID: 31990 java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.danyalahmed.stockmanagement/com.example.danyalahmed.stockmanagement.Activities.ListProducts}: java.lang.IllegalArgumentException: column '_id' does not exist at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2379) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2442) at android.app.ActivityThread.access$800(ActivityThread.java:156) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1351) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:211) at android.app.ActivityThread.main(ActivityThread.java:5373) at java.lang.reflect.Method.invoke(Native Method) at java.lang.reflect.Method.invoke(Method.java:372) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1020) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:815) Caused by: java.lang.IllegalArgumentException: column '_id' does not exist at android.database.AbstractCursor.getColumnIndexOrThrow(AbstractCursor.java:303) at android.widget.CursorAdapter.init(CursorAdapter.java:172) at android.widget.CursorAdapter.(CursorAdapter.java:149) at com.example.danyalahmed.stockmanagement.Classes.Populate_Products.(Populate_Products.java:20) at com.example.danyalahmed.stockmanagement.Activities.ListProducts.loadData(ListProducts.java:52) at com.example.danyalahmed.stockmanagement.Activities.ListProducts.onCreate(ListProducts.java:37) at android.app.Activity.performCreate(Activity.java:5990) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2332) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2442)  at android.app.ActivityThread.access$800(ActivityThread.java:156)  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1351)  at android.os.Handler.dispatchMessage(Handler.java:102)  at android.os.Looper.loop(Looper.java:211)  at android.app.ActivityThread.main(ActivityThread.java:5373)  at java.lang.reflect.Method.invoke(Native Method)  at java.lang.reflect.Method.invoke(Method.java:372)  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1020)  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:815)

ответ

3

Cursor имена столбцов чувствительны к регистру и CursorAdapter ожидает увидеть в нижнем регистре _id. (Сами идентификаторы SQL не чувствительны к регистру.)

Либо переименуйте столбец и заново создайте таблицу, либо просто выберите ее явно в нижнем регистре, например. SELECT _id, ....

1

Попробуйте _id вместо _ID в CREATE Оператор-

"CREATE TABLE IF NOT EXISTS Product (
_id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL UNIQUE , 
Name VARCHAR NOT NULL, 
Code VARCHAR NOT NULL, 
Quantity VARCHAR NOT NULL, 
PRICE DOUBLE NOT NULL);" 
Смежные вопросы