37

我正在探索从两个或多个连接表中优雅地获取数据的不同方法。

我相信MergeCursor,(Android 开发人员指南)似乎暗示可以(例如)SQL UNION通过连接两个查询(或将视图单独添加为行等)来替换等价物——所以,这不是我想要的。

但我不知道究竟是什么CursorJoinerMatrixCursor是为了什么,或者如何使用它们。我已经查看了它们的来源,并且(像往常一样)这对我来说毫无意义!我在使用中发现的示例并没有清楚地解释产生的效果。我真的很感激对它们的良好描述,以及它们可能被使用的上下文。

4

2 回答 2

72

MergeCursor,正如您所指出的,旨在“垂直”连接两个数据集,添加更多行。

CursorJoiner旨在“水平”连接两个数据集,添加更多列。您可以认为这类似于实现一个简单的SQL JOIN.

MatrixCursor允许您使用纯数据构建实现Cursor接口的东西,然后将其倒入二维数据模型中。

AbstractCursor允许您将自己的自定义数据集包装在Cursor接口中,覆盖必要的方法。

于 2011-04-18T12:54:19.283 回答
0

关于MatrixCursor,这里有一个使用示例。

这将返回数据的解密版本(在这种情况下只有一列,但在完整版本中,许多列是加密的)。

public MatrixCursor decyrptedCard(long cardid) {
    EncryptDecrypt ed = new EncryptDecrypt(mContext,
            LoginActivity.getCurrentUserPassWord(),
            MainActivity.mCurrentUserid);
    String[] mcsrcolumns = {
            DBCardsTableConstants.CARDID.getDBColumnName(),
            DBCardsTableConstants.CARDNAMEONCARD.getDBColumnName()
    };
    MatrixCursor cnvcsr = new MatrixCursor(mcsrcolumns,0);
    String whereclause = DBCardsTableConstants.CARDID.getDBColumnName() +
            "=?";
    String[] whereargs = {Long.toString(cardid)};

    Cursor basecsr = db.query(DBCardsTableConstants.CARDS.getDBTableName(),
            null,
            whereclause,
            whereargs,
            null,null,null,null);
    if (!basecsr.moveToFirst()) {
        cnvcsr.addRow(new Object[]{0L,"NOTACARD"});
        return cnvcsr;
    }

    cnvcsr.addRow(new Object[]{
            basecsr.getLong(
                    basecsr.getColumnIndex(
                            DBCardsTableConstants.CARDID.getDBColumnName()
                    )),
            ed.decrypt(
                    basecsr.getString(
                            basecsr.getColumnIndex(
                                    DBCardsTableConstants.CARDNAMEONCARD.getDBColumnName()
                            )
                    )
            )
    });
    basecsr.close();
    return cnvcsr;
}

简而言之,它与使用普通光标几乎没有什么不同,除了在创建实例时定义列。然后,您可以使用该addRow方法添加行。

于 2017-09-15T08:01:00.710 回答