使用lucene.net2.0 搜索数据库的例子<转自csdn>


#region 建立索引
public void CreateIndex()
{
DataSet ds = 取得数据库信息;
//取得索引输出
IndexWriter writer = new IndexWriter(这个地方写保存路径, true);
writer.SetMergeFactor(20); // 调整segment合并的频率和大小
//建立索引字段
if (ds.Tables[0] != null && ds.Tables[0].Rows.Count > 0)
{
foreach (DataRow dr in ds.Tables[0].Rows)
{
//取得Doc对象
Document doc = GetDocumentObj(文档信息写在这里,根据实际情况可以包含标题,内容,时间etc);
//写入索引文档
writer.AddDocument(doc);
}
}
//优化文档
writer.Optimize();
//关闭
writer.Close();
}
#endregion
#region 更新索引
/// <summary>
/// 通过fileindex的fileid更新 这个地方由于2.0不像java的2.2有update方法,所以只能先删除后添加了
/// </summary>
/// <param name="fileID"></param>
public void UpdateIndex(int fileID)
{
//这里根据ID取得信息对象IdxObj;
if (fileIdxObj == null) //无法查询,返回
return;
//取得索引修改器
IndexModifier modifier = new IndexModifier(路径, false);
//删除原索引
modifier.DeleteDocuments(new Term(此处根据fileid查询));
//建立索引字段
Document doc = GetDocumentObj(idxObj的信息);
//写入索引文档
modifier.AddDocument(doc);
//优化
modifier.Optimize();
//关闭
modifier.Close();
}
#endregion
#region 添加索引
public void AddIndex(信息)
{
//取得索引修改器
IndexModifier modifier = new IndexModifier(路径, new StandardAnalyzer(), false);
//建立索引字段
Document doc = GetDocumentObj(信息);
//写入索引文档
modifier.AddDocument(doc);
//优化
modifier.Optimize();
//关闭
modifier.Close();
}
#endregion
#region LuceneSearch
/// <summary>
/// 根据keyword检索数据,反回已分页的Dataset
/// </summary>
/// <param name="keyword">查找的关键字</param>
/// <param name="pageSize">分页每页的大小</param>
/// <param name="pageIndex">反回第几页的数据</param>
/// <returns>结果数据集,Tables[0]是结果数据,Tables[1]是存放总记录数(total数据)以及总页数的表</returns>
public DataSet LuceneSearch(string keyword, Int32 pageSize, Int32 pageIndex)
{
//取得表结构
DataTable mytab = GetDataTable();
int result = 0; //结果
int pageCount=0; //页数
int startPost = 0;
DataSet ds;
Query query;
IndexSearcher mysea;
//取得搜索结果
Hits myhit = seacher(keyword,out mysea, out query);
Highlighter hl = new Highlighter(new SimpleHTMLFormatter("<font class=\"Highlighter\">", "</font>"), new QueryScorer(query));
//设置高亮检索的范围 数值大=准确度高+速度慢
hl.SetMaxDocBytesToAnalyze(int.MaxValue);
if (myhit != null)
{
result = myhit.Length();
//计算分页信息
cacuPageInfo(pageSize, ref pageIndex, result, ref pageCount, ref startPost);
for (int i = 0; i < pageSize && startPost < result; i++, startPost++)
{
//添加信息
AppendTableRow(keyword, mytab, myhit, hl, startPost);
}
//填充结果
ds= FillResultDataSet(mytab, result, pageCount);
}
else
{
ds= null;
}
if(mysea!=null)
mysea.Close(); //关闭查询
return ds;
}
/// <summary>
/// 取得搜索信息
/// </summary>
/// <param name="queryString"></param>
/// <param name="query"></param>
/// <returns></returns>
public Hits seacher(String queryString,out IndexSearcher mysea, out Query query )
{
Hits hits = null;
try
{
mysea = new IndexSearcher(路径);
QueryParser qp = new QueryParser(查询字段, new StandardAnalyzer());
query = qp.Parse(queryString);
hits = mysea.Search(query);
}
catch (Exception e)
{
query = null;
mysea = null;
}
return hits;
}
分类:
Lucene.Net
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?