如果您使用RealmResults< T>,则没有理由对Realm使用分页.直接,因为RealmResults中的元素是惰性求值的,并且在调用.get(i)之前不在内存中.
意思是,在您直接索引它之前,查询不会执行和评估元素.这意味着,他们不在记忆中. RealmResults< T> list实际上并不包含元素,它只知道如何找到它们.
因此,Realm中没有LIMIT.
请注意,如果我没记错的话,重新评估findAllSorted未返回的两个RealmResults可以有不同的排序(如果发生删除).如果订单无论如何都必须相同,那么考虑一个排名属性,并按findAllSorted(“rank”,Sort.ASCENDING)排序.
如果你真的想要分页,你应该有排名参数,然后你可以创建一个查询
realm.where(SomeClass.class)
.greaterThanOrEqualTo("rank", pageSize*pageIndex + 0)
.lessThan(SomeClassFields.RANK, pageSize*pageIndex + pageSize)
.findAllSorted(SomeClassFields.RANK, Sort.ASCENDING);
compile 'io.realm:android-adapters:1.3.0' // for Realm 0.89.0 to Realm 2.3.0
要么
compile 'io.realm:android-adapters:2.1.0' // for Realm 3.0.0+
RealmRecyclerViewAdapter为您处理“加载新数据”,除了设置初始RealmResults之外,您无需执行任何操作.
一旦与Paging Architecture Component正确集成,我真的必须改变这个答案,Paging Architecture Component知道吗?我有一个实验here,你可以看看它是否适合你.