java - Android - 光标找不到列

标签 java android

我正在尝试从 Cursor 获取结果并将它们放入我创建的对象中。在 Eclipse 中,游标似乎返回单行(这是我想要的)但是当我尝试访问它时,出现错误。这是获取单行的代码:

public Object fetchIssue(long IssueNumber, int type){

    //Get query cursor.
    Cursor cursor = mDB.query(true, ISSUES_TABLE, ISSUES_COLUMN_ARRAY, COL_ISSUE_ID + "=" + IssueNumber, null, null, null, null, null);

    int iCount = cursor.getCount();

    if(cursor == null)
        return null;

    Object objOut = null;

    if(type == QUERY_TYPE_STRING_ARRAY){
        //Create Array to hold Issue Information.
        String[] IssueInfo = new String[3];
        IssueInfo[0] = String.valueOf(IssueNumber);
        IssueInfo[1] = cursor.getString(cursor.getColumnIndexOrThrow(COL_DATE_RECEIVED));
        IssueInfo[2] = cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_SUMMARY));
        IssueInfo[3] = cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_STATUS));
        IssueInfo[4] = cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_SUB_STATUS));
        IssueInfo[5] = cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_DESCRIPTION));
        objOut = IssueInfo;
    }
    else{
        //Create IssueInfo object.
        IssueInfo IssueInfo = new IssueInfo(
                    IssueNumber, "12/12/2000",
                    //cursor.getString(cursor.getColumnIndexOrThrow(COL_DATE_RECEIVED)),
                    cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_SUMMARY)),
                    cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_STATUS)),
                    cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_SUB_STATUS)),
                    cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_DESCRIPTION)));
        objOut = IssueInfo;
    }

    //Close cursor.
    cursor.close();

    //Return IssueInfo.
    return objOut;
}

iCount 返回 1,如果我将光标变量放在“变量”窗口中,我可以看到所有列: Cursor variable

并且在类的顶部,表列变量设置为相同的名称:

public static final String ISSUES_TABLE = "Issues";
public static final String COL_ISSUE_ID = "_id";
public static final String COL_DATE_RECEIVED = "DateReceived";
public static final String COL_ISSUE_STATUS = "IssueStatus";
public static final String COL_ISSUE_SUB_STATUS = "IssueSubStatus";
public static final String COL_ISSUE_SUMMARY = "IssueSummary";
public static final String COL_ISSUE_DESCRIPTION = "IssueDescription";

private static final String[] ISSUES_COLUMN_ARRAY = new String[]{
    COL_ISSUE_ID, COL_DATE_RECEIVED, COL_ISSUE_SUMMARY, 
    COL_ISSUE_STATUS, COL_ISSUE_SUB_STATUS, COL_ISSUE_DESCRIPTION};

错误发生在这一行:

//Create IssueInfo object.
        IssueInfo IssueInfo = new IssueInfo(
                    IssueNumber, "12/12/2000",
                    //cursor.getString(cursor.getColumnIndexOrThrow(COL_DATE_RECEIVED)),
                    cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_SUMMARY)),
                    cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_STATUS)),
                    cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_SUB_STATUS)),
                    cursor.getString(cursor.getColumnIndexOrThrow(COL_ISSUE_DESCRIPTION)));

或其中任何一行(如您所见,我注释掉了接收日期并在其中放置了一个正常的字符串值,它需要)。

这是错误:

03-13 09:06:42.370: E/AndroidRuntime(2324): FATAL EXCEPTION: AsyncTask #2
    03-13 09:06:42.370: E/AndroidRuntime(2324): java.lang.RuntimeException: An error occured while executing doInBackground()
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at android.os.AsyncTask$3.done(AsyncTask.java:278)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at java.util.concurrent.FutureTask.run(FutureTask.java:137)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at java.lang.Thread.run(Thread.java:856)
    03-13 09:06:42.370: E/AndroidRuntime(2324): Caused by: android.database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 1
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at android.database.AbstractCursor.checkPosition(AbstractCursor.java:400)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:136)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:50)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at com.adacel.dashboard.DBAdapter.fetchIssue(DBAdapter.java:215)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at com.adacel.dashboard.IssueInfoCreator.fetchIssue(IssueInfoCreator.java:42)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at com.adacel.dashboard.ViewIssue.LoadIssueDetails(ViewIssue.java:73)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at com.adacel.dashboard.ViewIssue.access$0(ViewIssue.java:70)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at com.adacel.dashboard.ViewIssue$GetIssueDetailsTask.doInBackground(ViewIssue.java:96)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at com.adacel.dashboard.ViewIssue$GetIssueDetailsTask.doInBackground(ViewIssue.java:1)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at android.os.AsyncTask$2.call(AsyncTask.java:264)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
    03-13 09:06:42.370: E/AndroidRuntime(2324):     ... 4 more

非常感谢任何帮助!

最佳答案

你必须首先移动到光标的第一个索引:

 cursor.moveToFirst();

关于java - Android - 光标找不到列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9684602/

相关文章:

android - 广播接收器未在 AndroidManifest.xml 中注册

android - 如何在同一个类中延伸两项 Activity ?

android - 需要按钮根据屏幕宽度动态展开

java - 在 Android 中从 XML 布局获取 View 不起作用

java - Java 方法的阻塞和解除阻塞

java - 野蝇群休息 Controller

java - Java 中的 Cookie 解析

java - 如何避免用户向数组添加重复的 int 值?

Java SWT - 在 shell 上使用 SWT.V_SCROLL 时 shell 的标题栏消失

Android 在发送短信时删除已选择的联系人