java.lang.IllegalStateException: 无法从CursorWindow读取第0行第0列的内容

5

我需要从一张表中获取所有数据,我在sqlite的dbhelper类中使用了以下代码来实现这个功能:

public Cursor getData() {
        SQLiteDatabase db = this.getWritableDatabase();
        Cursor res = db.rawQuery("select * from " + PRODUCT_DETAILS_TABLE, null);
        return res;
    }

现在我正在使用活动中的光标以以下方式获取数据:
  public HashMap<String, ArrayList<CartModal>> getDatas() {

            map = new HashMap<String, ArrayList<CartModal>>();
            stored_data = new ArrayList<CartModal>();
            Cursor cartdb = dbHelper.getData();
            if (cartdb != null && cartdb.getCount() > 0) {
                if (cartdb.moveToFirst()) {
                    do {
                        String mloggedinuser = cartdb.getString(0);
                        String mname = cartdb.getString(1);
                        String email = cartdb.getString(2);
                        String mobile = cartdb.getString(3);
                        String about = cartdb.getString(4);
                        String pid = cartdb.getString(5);
                        String refnum = cartdb.getString(6);
                        String size = cartdb.getString(7);
                        String weight = cartdb.getString(8);
                        String price = cartdb.getString(9);
                        String catid = cartdb.getString(10);
                        String image = cartdb.getString(11);

                        CartModal cartarray = new CartModal(mloggedinuser, mname, email, mobile, about, pid, refnum, size, weight, price, catid, image);
                        stored_data.add(cartarray);
                        keys = mname;
                        map.put(mname, stored_data);
                    } while (cartdb.moveToPosition(stored_data.size()));
                    cartdb.close();
                }
            }
            return map;
        }

当我运行上述程序时,我收到以下错误信息:
E/AndroidRuntime: FATAL EXCEPTION: main
                  Process: sdetech.io.brouchuretabproject, PID: 2434
                  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:438)
                      at android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:51)
                      at sdetech.io.brouchuretabproject.Fragments.Cart.getDatas(Cart.java:58)
                      at sdetech.io.brouchuretabproject.Fragments.Cart.onCreateView(Cart.java:42)
                      at android.support.v4.app.Fragment.performCreateView(Fragment.java:2087)
                      at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1113)
                      at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1295)
                      at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:801)
                      at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1682)
                      at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:541)
                      at android.os.Handler.handleCallback(Handler.java:739)
                      at android.os.Handler.dispatchMessage(Handler.java:95)
                      at android.os.Looper.loop(Looper.java:148)
                      at android.app.ActivityThread.main(ActivityThread.java:5417)
                      at java.lang.reflect.Method.invoke(Native Method)
                      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

我在stackoverflow上查看了很多解决方案(android java.lang.IllegalStateException: Couldn't read row 0, col 0 from CursorWindow),但是没有一个能帮助我解决这个问题。 请给我提供一个解决方案。


我无法在代码中找到任何逻辑错误,也许你可以尝试手动调试代码,设置断点并查看哪里出了问题。 - Hardik Modha
@pskink,你能告诉我在上面的方法中我哪里做错了吗? - user4520896
我已经翻译了:“你只有一个stored_data实例,而且你一遍又一遍地向该实例添加新数据”,但说实话,你是错的,因为你没有使用SimpleCursorTreeAdapter - pskink
@pskink,您能向我展示如何在上面的代码中使用SimpleCursorTreeAdapter吗? - user4520896
请注意getChildrenCursor方法:https://android.googlesource.com/platform/development/+/master/samples/ApiDemos/src/com/example/android/apis/view/ExpandableList2.java - pskink
显示剩余9条评论
1个回答

0
我一直在做正确的事情。但问题是,我将图像保存为base64编码字符串存储在数据库中。当获取数据时,它显示非法异常。当我删除该图像时,它可以完美地工作。
如果有人知道如何将base64编码的图像保存为字符串在sqlite中,请在下面回复。
谢谢。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接