Anda dapat menggunakan CursorJoiner untuk mendapatkan sesuatu yang mirip dengan menggabungkan dua Kursor menjadi satu. CursorJoiner sebenarnya tidak melakukan penggabungan. Saat Anda mengulanginya, itu memindahkan dua Kursor asli sehingga barisnya akan cocok dengan kolom yang ditentukan. Inilah mengapa kedua Kursor perlu diurutkan pada kolom yang akan digunakan dalam gabungan.
Tautan ke dokumentasi:http://developer.android.com/reference/android/database/CursorJoiner.html
Contoh kode:
CursorJoiner joiner = new CursorJoiner(userCursor, new String[]{ "user_id" }, postCursor, new String[] {"user_id"});
while (joiner.hasNext()) {
CursorJoiner.Result result = joiner.next();
switch (result) {
case LEFT:
// don't care about this case
break;
case RIGHT:
// nor this case
break;
case BOTH:
// here both original Cursors are pointing at rows that have the same user_id, so we can extract values
int postId = postCursor.getInt(...);
String headline = postCursor.getString(...);
int userId = userCursor.getInt(...);
String userName = userCursor.getString(...);
// do something with above values
break;
}
}