使用MergeCursor和SimpleCursorAdapter,有什么缺失?

时间:2012-05-13 05:59:43

标签: android listview simplecursoradapter mergecursor

无论我做什么,下面都会抛出一个错误,即cursor_counterparty中包含的一个列不存在。当我检查merge_cursor时,我可以找到那里的列,这是我的代码,我做错了什么?

cursor_invoices = Invoices.getInvoicesCursor(counterparty.getId());
    Cursor cursor_counterparty = Counterparties
            .getCounterpartyCursor(counterparty.getId());
    startManagingCursor(cursor_invoices);
    startManagingCursor(cursor_counterparty);

    /* Joins cursors akin to doing an SQL join */

    MergeCursor merge_cursor = new MergeCursor(new Cursor[] {
            cursor_invoices, cursor_counterparty });
    merge_cursor.moveToFirst();

    int[] listview_columns = new int[] { R.id.textview_invoice_number,
            R.id.textview_counterparty_name, R.id.textview_amount,
            R.id.textview_account_name, R.id.textview_invoice_date,
            R.id.textview_date_paid };
    String[] listview_fields = new String[] { App.INVOICENUMBER,
            App.COUNTERPARTYNAME, counterparty_amount_field,
            App.ACCOUNTNAME, App.INVOICEDATE, App.DATEPAID };

    SimpleCursorAdapter cursor_adapter_invoices = new SimpleCursorAdapter(
            this, R.layout.listview_invoice_item, merge_cursor,
            listview_fields, listview_columns);

我得到的错误是:

  

java.lang.IllegalArgumentException:列'counterparty_name'不存在

当我调试App时,我可以将'counterparty_name'视为merge_cursor中其中一个游标的列。

任何帮助都会很棒,谢谢!

1 个答案:

答案 0 :(得分:4)

您想要垂直(添加行)还是水平(添加列)加入游标?

这是理论,因为我没有偷看代码,但它对我有意义......

MergeCursor一个接一个地垂直连接游标(事实)。因此,对于游标的一部分,您有一组列,而另一组则有一组不同的列(假设)。

您的适配器正在尝试查找显示的行的一部分或另一部分中不存在的列。

如果您更改为连接列的CursorJoiner,我认为它会更像您期望的工作,尽管如何恰当地排列行我不知道。

一个很好的解释here

修改

我看到你使用相同的ID来获取每个光标,所以我对将它们排成一行的担忧是无关紧要的。我想你确实想要CursorJoiner而不是MergeCursor。