gpt4 book ai didi

来自 CursorWindow 的 java.lang.IllegalStateException : Couldn't read row 0, col 0

转载 作者:IT王子 更新时间:2023-10-29 06:30:02 32 4
gpt4 key购买 nike

我需要从表中获取所有数据,我使用以下代码在 sqlite dbhelper 类中执行相同的操作:

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

现在我通过以下方式在我的 Activity 中使用光标获取数据:

  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 ) 中尝试过很多解决方案,但没有一个能帮助我解决这个问题。请给我一个解决方案。

最佳答案

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

谢谢

关于来自 CursorWindow 的 java.lang.IllegalStateException : Couldn't read row 0, col 0,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41519419/

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