hibernate search ,lucene查询

hibenrate search的查询与lucene的查询基本相同下边我说一下简的查询过程,前担是我们已经建立索引库了。

1、获取FullTextSession 因为我们的索引是是在数据库发生事件时建立的。我们就要获取相关的session来取得以后的吕作

2、像我们hql查询一样,我们也需要定义一个查询的条件

3、因为是全文检索,我们已经对文章进行了分词的处理. 所以以我们也要对输入的文本进行分词的处理,

4、执行查询,由于我们刚学习,这里要看一个查询语句。

下边是hibernate search 的lucene查询源码

ArticleDAO dao = new ArticleDAO();
  String searchQuery = "new";
  FullTextSession ftsSession = Search
    .getFullTextSession(dao.getSession());
  String[] fields = { "articleTitle", "articleSummery" };
  QueryParser parset = new MultiFieldQueryParser(fields,
    new StandardAnalyzer());
  try {
   org.apache.lucene.search.Query luceneQuery = parset
     .parse(searchQuery);
   System.out.println(luceneQuery);
  } catch (ParseException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  ftsSession.close();

 

 

还有多条件查询String searchQuery = "Batman";
String[] productFields = {"title", "description"};
Map<String,Float> boostPerField = new HashMap<String,Float>(2);
boostPerField.put( "title", (float) 4);
boostPerField.put( "description", (float) 1);
QueryParser parser = new MultiFieldQueryParser(
productFields,
new StandardAnalyzer(),
boostPerField
);
org.apache.lucene.search.Query luceneQuery;
try {
luceneQuery = parser.parse(searchQuery);
}
catch (ParseException e) {
throw new RuntimeException("Unable to parse query: " + searchQuery, e);
}

 

 

下边是hibnerate search 的查询

FullTextSession ftSession = Search.getFullTextSession(session);
org.hibernate.Query query = ftSession.createFullTextQuery(luceneQuery,Item.class);
query = ftSession.createFullTextQuery(luceneQuery);
query = ftSession.createFullTextQuery(luceneQuery,Item.class,Actor.class);

List results = query.getResultList();

for (Item item : (List<Item>) results) {
display( "title: " + item.getTitle() + "\nDescription: " +
item.getDescription() );
}

 

 

在这里可以看到一些内容

你可能感兴趣的:(DAO,apache,Hibernate,Lucene,全文检索)