简单查询返回错误

时间:2013-03-06 05:52:40

标签: android android-sqlite

这是我的Log Cat

          java.lang.RuntimeException: Unable to start activity   ComponentInfo{XXXXXX}: java.lang.IllegalStateException:   Couldn't read row 0, col 0 from CursorWindow. Make sure the Cursor is initialized correctly   before accessing data from it.
         at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1960)
         at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1985)
         at android.app.ActivityThread.access$600(ActivityThread.java:127)
         at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1151)
         at android.os.Handler.dispatchMessage(Handler.java:99)
         at android.os.Looper.loop(Looper.java:137)
         at android.app.ActivityThread.main(ActivityThread.java:4482)
         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:794)
         at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:561)
         at dalvik.system.NativeStart.main(Native Method)
         Caused by: java.lang.IllegalStateException: Couldn't read row 0, col 0 from      CursorWindow. Make sure the Cursor is initialized correctly before accessing data from it.
         at android.database.CursorWindow.nativeGetString(Native Method)
         at android.database.CursorWindow.getString(CursorWindow.java:442)
         at android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:51)
         at com.gallops.CheckProfile.fillData(CheckProfile.java:171)
         at com.gallops.CheckProfile.onCreate(CheckProfile.java:154)
         at android.app.Activity.performCreate(Activity.java:4728)
         at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1051)
         at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1924)
         ... 11 more

我正在尝试运行的查询: // DBAdapter文件

   public Cursor fetchRow(String a) {
            String Key = a; 
            return mDb.query(DATABASE_TABLE0, new String[] {IDno1, GIDno1,Name1,Owner1,Breed1,Gender1, Notes1,Nature1,Color1,Sire1,Dam1,Height1,Foaled1,Acquired1,Date1,IMG}, "IDno=?",new String[]{Key}, null, null, null, null);
}

我给它打电话的功能:

           private void fillData() {
    String D = getid();

  Cursor c = DBHelper.fetchRow(IDB);

   // List<String> idList = new ArrayList<String>();
    if (c.moveToFirst()) {
        do {
            String X = (c.getString(c.getColumnIndexOrThrow("IDno")));
            TextView tv2=(TextView)findViewById(R.id.textView3);
            tv2.setText(X);

            String B = (c.getString(c.getColumnIndexOrThrow("GIDno")));
            TextView tv6=(TextView)findViewById(R.id.textView7);
            tv6.setText(B);

            String A = (c.getString(c.getColumnIndexOrThrow("Name")));
            TextView tv=(TextView)findViewById(R.id.textView1);
            tv.setText(A);
            NameTop = A; 

            String Y = (c.getString(c.getColumnIndexOrThrow("Owner")));
            TextView tv12=(TextView)findViewById(R.id.textView13);
            tv12.setText(Y);

            String G = (c.getString(c.getColumnIndexOrThrow("Breed")));
            TextView tv10=(TextView)findViewById(R.id.textView11);
            tv10.setText(G);

            String N = (c.getString(c.getColumnIndexOrThrow("Notes")));
            TextView tv8=(TextView)findViewById(R.id.textView9);
            tv8.setText(N);

            String da = (c.getString(c.getColumnIndexOrThrow("Dam")));
            TextView tv14=(TextView)findViewById(R.id.TextView02);
            tv14.setText(da);

            String si = (c.getString(c.getColumnIndexOrThrow("Sire")));
            TextView tv16=(TextView)findViewById(R.id.TextView04);
            tv16.setText(si);

            String co = (c.getString(c.getColumnIndexOrThrow("Color")));
            TextView tv18=(TextView)findViewById(R.id.TextView06);
            tv18.setText(co);


            String g = (c.getString(c.getColumnIndexOrThrow("Gender")));
            TextView tv20=(TextView)findViewById(R.id.TextView08);
            tv20.setText(g);


            String na = (c.getString(c.getColumnIndexOrThrow("Nature")));
            TextView tv22=(TextView)findViewById(R.id.TextView10);
            tv22.setText(na);


            String he = (c.getString(c.getColumnIndexOrThrow("Height")));
            TextView tv24=(TextView)findViewById(R.id.TextView12);
            tv24.setText(he);


            String fo = (c.getString(c.getColumnIndexOrThrow("Foaled")));
            //TextView tv26=(TextView)findViewById(R.id.TextView14);
            //tv26.setText(fo);


            String ac = (c.getString(c.getColumnIndexOrThrow("Acquired")));
            TextView tv28=(TextView)findViewById(R.id.TextView16);
            tv28.setText(ac);

           /*Dt = (c.getString(c.getColumnIndexOrThrow("Date")));
            int age = age(Dt);
            TextView Tvx =(TextView)findViewById(R.id.textView5);
            String DD = Integer.toString(age);
            Tvx.setText(DD); */

            Image = c.getBlob(c.getColumnIndex("image"));

            if (Image!=null){
            BitmapFactory.Options options = new BitmapFactory.Options();
                    bitmap = BitmapFactory.decodeByteArray(Image, 0, Image.length, options); 
                    ImageView Img = (ImageView)findViewById(R.id.imageView1);
                    Img.setImageBitmap(bitmap); 
            }else{
                ImageView Img = (ImageView)findViewById(R.id.imageView1);
                Img.setBackgroundResource(R.drawable.pic); 
            }

        } while (c.moveToNext());
        DBHelper.close();

    } 
}

2 个答案:

答案 0 :(得分:1)

试试这个

在您的活动中全局声明一个Cursor

光标数据光标;

 And then assign to datacursor instead of c.

 datacursor = DBHelper.fetchRow(IDB);

使用datacursor

访问该行

答案 1 :(得分:1)

您可能想要编写一些输出到logcat的调试行,以确保您实际获取光标中的信息并获得您认为应该的信息。

在尝试使用光标之前,还需要检查光标是否为空。如果光标为null,则应用程序将崩溃。我学到了很难的方法。您可以使用以下方法检查空游标:

if(cu != null && cu.getCount() > 0){
    cu.moveToFirst();
    // The rest of your code
}