Lucene3.0 对数据库数据进行搜索

本文介绍了一种使用Lucene库对数据库中指定表的全文本信息进行索引和检索的方法。通过Java代码实现,展示了如何连接数据库、获取表数据、创建索引并进行关键词查询。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.orifound.aiim.web.util;

import java.io.File;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.queryParser.QueryParser;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.ScoreDoc;
import org.apache.lucene.search.TopScoreDocCollector;
import org.apache.lucene.store.Directory;
import org.apache.lucene.store.FSDirectory;
import org.apache.lucene.util.Version;

/**
*
* @描述 对数据库数据进行搜索
*/
public class LuceneUtil {

// 保存路径
private static String INDEX_DIR = "D:\\Lucene\\index";
private static Analyzer analyzer = new StandardAnalyzer(Version.LUCENE_30);
private static Directory directory = null;

/**
* 建立索引
* @param args
*/
public static void index() throws Exception{
directory = FSDirectory.open(new File(INDEX_DIR));
File indexFile = new File(INDEX_DIR);
if (!indexFile.exists()) {
indexFile.mkdirs();
}

//if (new File(INDEX_DIR).listFiles().length <= 0) {
IndexWriter indexWriter = new IndexWriter(directory, analyzer,IndexWriter.MaxFieldLength.LIMITED);

Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
Connection connection = DriverManager.getConnection("jdbc:sqlserver://bbs:1433;DatabaseName=AIIM_DB;userName=sa;password=123456");
PreparedStatement statement = connection.prepareStatement("select * from ArchivesInfoAttachedFileFullTextInfo");
ResultSet resultSet = statement.executeQuery();
while (resultSet.next()) {
Document document = new Document();
document.add(new Field("ID", resultSet.getString("ID"),Field.Store.YES, Field.Index.ANALYZED));
document.add(new Field("FullText", resultSet.getString("FullText"), Field.Store.YES, Field.Index.ANALYZED));
indexWriter.addDocument(document);
}

indexWriter.optimize();// 优化
indexWriter.close();
resultSet.close();
statement.close();
connection.close();
//}
}

/**
* 关键字查询
* @param str
* @throws Exception
*/
public static void search(String str) throws Exception{
directory = FSDirectory.open(new File(INDEX_DIR));
IndexSearcher indexSearcher = new IndexSearcher(directory, true);

String fieldname = "FullText";
QueryParser queryParser = new QueryParser(Version.LUCENE_30,fieldname, analyzer);
Query query = queryParser.parse(str);
TopScoreDocCollector topScoreDocCollector = TopScoreDocCollector.create(100, true);
indexSearcher.search(query, topScoreDocCollector);
ScoreDoc[] scoreDocs = topScoreDocCollector.topDocs().scoreDocs;
for (int i = 0; i < scoreDocs.length; i++) {
Document doc = indexSearcher.doc(scoreDocs[i].doc);
System.out.println(doc.get("ID"));
System.out.println("------------------------------------------------");
}
}


public static void main(String[] args) {
try {
//LuceneUtil.index();
LuceneUtil.search("成绩");
} catch (Exception e) {
e.printStackTrace();
}
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值