本站首页    管理页面    写新日志    退出


«October 2025»
1234
567891011
12131415161718
19202122232425
262728293031


公告
本博客在此声明所有文章均为转摘,只做资料收集使用。并无其他商业用途。

我的分类(专题)

日志更新

最新评论

留言板

链接

Blog信息
blog名称:
日志总数:210
评论数量:205
留言数量:-19
访问次数:923079
建立时间:2007年5月10日




[开源面向对象数据库db4o之旅]如何在db4o进行分页?
文章收藏,  网上资源,  软件技术,  电脑与网络

李小白 发表于 2008/4/7 15:31:16

  可以用Evaluation 来实现, 例如:    query.constraints(new FilterEvaluation(pageSize))  public class FilterEvaluation implements Evaluation { private static final long serialVersionUID = 1L; private int size = -1 ; private int index ; public FilterEvaluation(int size) { this.size = maxSize; index = 0 ; } public void evaluate(Candidate candidate) { if(index < maxSize) {     candidate.include(true);    index ++; }else {       candidate.include(false); }   }     关于查询结果的排序:可以使用方法ObjectContainer.query(Predicate, Comparator)为你的对象构造一个或多个java.util.Comparator这样查询结果将会根据你指定的比较算法,进行排序。   想象一个 .net 的查询写法:  IEnumerable<Person> myQuery(int a,int b) {     IQuery q=db.Query();     q.Constrain(typeof(Person));     q.Descend("姓名").OrderAscending();     IObjectSet result=q.Execute();     int p=0;     while(result.HasNext() && p<b)     {       if(p<a)           result.Next();       else           yield return result.Next();       p++;     }     yield break; }   查询例如: foreach(Person obj in myQuery(10,20))  Console.Write(obj.ToString());  我使用6.0和6.1测试,在建立了索引并且查询表达方式注意了应该可以使用到索引的情况下,我使用上万业务数据查询,发现NQ查询的性能即使对单个字段搜索一个固定值的查询也根本无法使用。一定要使用SODA查询。


阅读全文(5379) | 回复(1) | 编辑 | 精华
 


回复:如何在db4o进行分页?
文章收藏,  网上资源,  软件技术,  电脑与网络

chrnc (游客)发表评论于2010/8/9 11:20:18

chrnc 关注一下


个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除
 


» 1 »

发表评论:
昵称:
密码:
主页:
标题:
验证码:  (不区分大小写,请仔细填写,输错需重写评论内容!)



站点首页 | 联系我们 | 博客注册 | 博客登陆

Sponsored By W3CHINA
W3CHINA Blog 0.8 Processed in 0.047 second(s), page refreshed 144790622 times.
《全国人大常委会关于维护互联网安全的决定》  《计算机信息网络国际联网安全保护管理办法》
苏ICP备05006046号