lucene之搜索索引

以下是通过lucene自带的  TermQuery来查询,即使用lucene自带的默认分词器,英文分词器进行分词。

       在以后的文章中会将到中文分词等相关内容。

(以下代码用在项目中会由io问题,最好再改进一下,这里只用了测试。考虑到公司代码安全问题,这里只给出开发中的部分测试代码。)


public ArrayList<String> queryByString(String queryStr){

        //上面文章中建立索引的文件目录
        File indexDir = new File("D:\\luceneIndex");
        FSDirectory directory;
        ArrayList<String> resultList=new ArrayList<String>(10);
        try {
            directory=FSDirectory.open(indexDir);
            
            IndexSearcher searcher=new IndexSearcher(directory);
             if(!indexDir.exists()){
                 System.out.println("The Lucene index is not exist");
                 return null;
            }
            //定义搜索的基本单位。第一个参数代表了要在文档的哪一个 Field 上进行查找,第二个参数代表了要查询的关键词。
            Term term = new Term("GoodsName",queryStr);
            //构造查询对象。构造函数只接受一个 Term 对象
            TermQuery luceneQuery = new TermQuery(term);
            //搜索需要查询对象,并返回结果
            TopDocs hit=searcher.search(luceneQuery, 10);
            
            for(int i=0;i<hit.totalHits;i++){
                ScoreDoc scoreDoc=hit.scoreDocs[i];
                Document hitDoc=searcher.doc(scoreDoc.doc);
                System.out.println("GoodsName: " + hitDoc.get("GoodsName"));
                String tempStr=hitDoc.get("GoodsName");
                resultList.add(tempStr);
            }
            
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
        return resultList;
    }

posted @ 2013-04-23 15:53  Dream-Weaver  阅读(145)  评论(0编辑  收藏  举报