Compass应用学习之搭建开发环境及书写compass工具类

[b]1.引入包搭建开发环境[/b]
Common-logging.jar, Compass-2.2.0.jar
Lucene-analyzers.jar, Lucene-core.jar
Lucene-highlighter.jar, Lucene-queries.jar
Lucene-snowball.jar, Lucene-spellchecker.jar
Je-analysis-1.5.3.jar //用于解决compass2.2不支持IKAnalyzer3.0分词器的问题

分词器analyzer说明
由于前面引入的compass2.2.jar 只支持到Lucene2.4版本,而IKAnalyzer当前最新版本只支持Lucene3.0不支持Lucene2.4,所以这里只能使用另一款分词器JE分词器.

[b]Compassutils.java工具类代码:[/b]
import org.compass.core.Compass;
import org.compass.core.config.CompassConfiguration;
import cn.itcast.lucene.domain.Article;

/**
*单态模式创建compass工厂类
*/
public class CompassUtils {
static Compass compass = null;
static {
CompassConfiguration cfg = new CompassConfiguration();
cfg.setConnection("./indexDir");//设置索引库位置
cfg.addClass(Article.class);//要映射的对象信息
compass=cfg.buildCompass();//创建compass工厂实例
}
//返回compass工厂类实例对象
public static Compass getCompass(){
return compass;
}
}
说明: 从上面代码可以看出,compass采用了与hibernate类似的对象映射机制,前者是orm对象关系映射,后者是osem对象搜索引挚映射.

[b]要映射的Article类核心代码(完成映射下面的注解必不可少)[/b]
@Searchable //代表可搜索的对象
public class Article {
@SearchableId //对象的唯一标识符
private Long id;
@SearchableProperty(store=Store.YES,index=Index.ANALYZED)//普通属性
private String title;
@SearchableProperty(store=Store.YES,index=Index.ANALYZED) //普通属性
private String content;
@SearchableProperty(store=Store.YES,index=Index.NOT_ANALYZED)
private Date postTime;//对DateTools工具类进行试验
@SearchableBoostProperty
private Float boostValue;//后续属性: 设置相关度排序属性可改变默认的按相关度查询的索引结果顺序
@SearchableProperty(store=Store.YES,index=Index.NOT_ANALYZED)
private Long viewCount;//后续属性: 访问次数

//getter/setter方法…………………………..
//说明: Store.YES 表示存储到索引库中, Index.ANALYZED/NOT_ANALYZED 表示进行/不进行分词
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值