今天工作不是特别多,在逛园子的时候看到了Lucene.Net,所以自己也参照别人的
博文自己动手写了个DEMO(虽然很多是参考过来的,不过自己动手更容易记住嘛!)。废话不多说,先上个图,把以前看到的几个好的jquery插件也用上
去了(JQuery关键字高亮度、JQuery分页),不记得地址了,就没有留作者的网址。

第一步,下载DLL文件,我这里用的是2.9的版本,貌似说不更新了。
第二步,把DLL引用到你的项目中,然后就是生成索引文件。
/// 执行查询语句,返回SqlDataReader
|
/// <param name="strSQL">查询语句</param>
|
/// <returns>SqlDataReader</returns>
|
public static SqlDataReader ExecuteReader(string strSQL)
|
SqlConnection connection = new SqlConnection(connectionString);
|
SqlCommand cmd = new SqlCommand(strSQL, connection);
|
SqlDataReader myReader = cmd.ExecuteReader();
|
catch (System.Data.SqlClient.SqlException e)
|
throw new Exception(e.Message);
|
public static IndexWriter CreateIndex(SqlDataReader myred)
|
IndexWriter writer = new IndexWriter("D:/index/", new StandardAnalyzer(), true);
|
Document doc = new Document();
|
doc.Add(new Field("ID", myred["ID"].ToString(), Field.Store.YES, Field.Index.UN_TOKENIZED));
|
doc.Add(new Field("Name", myred["Name"].ToString(), Field.Store.YES, Field.Index.TOKENIZED));
|
doc.Add(new Field("Add", myred["Add"].ToString(), Field.Store.YES, Field.Index.TOKENIZED));
|
好了,索引文件已经建好了。
第三步,查询我们需要的数据鸟。
Stopwatch sw = new Stopwatch();
|
string path = "D:/index/";
|
Sort sort = new Sort(new SortField("ID", SortField.DOC, false));
|
IndexSearcher searcher = new IndexSearcher(path);
|
QueryParser q = new QueryParser("Name", new StandardAnalyzer());
|
Query query = q.Parse(strwhere);
|
Hits hits = searcher.Search(query, sort);
|
int num = pagesize + pages * pagesize;
|
int emdnum = pages * pagesize;
|
for (int i = emdnum; i < num; i++)
|
Document doc = hits.Doc(i);
|
str += "<p><a href=\"Show.aspx?ID=" + doc.Get("ID") + "\" title=\"" + doc.Get("Name") + "\">" + doc.Get("Name") + "</a></p>";
|
str += "<p>搜索结果为 " + hits.Length() + " 个 耗时:" + sw.ElapsedMilliseconds.ToString() + "毫秒</p>";
|
这样基本查询功能就OK了。写篇博客记录下,给自己加深下印象。明天有时间还得捣鼓捣鼓分词,内置分词不是很好。
代码写的很乱,还是提供个下载。(点击下载)
今天工作不是特别多,在逛园子的时候看到了Lucene.Net,所以自己也参照别人的
博文自己动手写了个DEMO(虽然很多是参考过来的,不过自己动手更容易记住嘛!)。废话不多说,先上个图,把以前看到的几个好的jquery插件也用上
去了(JQuery关键字高亮度、JQuery分页),不记得地址了,就没有留作者的网址。

第一步,下载DLL文件,我这里用的是2.9的版本,貌似说不更新了。
第二步,把DLL引用到你的项目中,然后就是生成索引文件。
/// 执行查询语句,返回SqlDataReader
|
/// <param name="strSQL">查询语句</param>
|
/// <returns>SqlDataReader</returns>
|
public static SqlDataReader ExecuteReader(string strSQL)
|
SqlConnection connection = new SqlConnection(connectionString);
|
SqlCommand cmd = new SqlCommand(strSQL, connection);
|
SqlDataReader myReader = cmd.ExecuteReader();
|
catch (System.Data.SqlClient.SqlException e)
|
throw new Exception(e.Message);
|
public static IndexWriter CreateIndex(SqlDataReader myred)
|
IndexWriter writer = new IndexWriter("D:/index/", new StandardAnalyzer(), true);
|
Document doc = new Document();
|
doc.Add(new Field("ID", myred["ID"].ToString(), Field.Store.YES, Field.Index.UN_TOKENIZED));
|
doc.Add(new Field("Name", myred["Name"].ToString(), Field.Store.YES, Field.Index.TOKENIZED));
|
doc.Add(new Field("Add", myred["Add"].ToString(), Field.Store.YES, Field.Index.TOKENIZED));
|
好了,索引文件已经建好了。
第三步,查询我们需要的数据鸟。
Stopwatch sw = new Stopwatch();
|
string path = "D:/index/";
|
Sort sort = new Sort(new SortField("ID", SortField.DOC, false));
|
IndexSearcher searcher = new IndexSearcher(path);
|
QueryParser q = new QueryParser("Name", new StandardAnalyzer());
|
Query query = q.Parse(strwhere);
|
Hits hits = searcher.Search(query, sort);
|
int num = pagesize + pages * pagesize;
|
int emdnum = pages * pagesize;
|
for (int i = emdnum; i < num; i++)
|
Document doc = hits.Doc(i);
|
str += "<p><a href=\"Show.aspx?ID=" + doc.Get("ID") + "\" title=\"" + doc.Get("Name") + "\">" + doc.Get("Name") + "</a></p>";
|
str += "<p>搜索结果为 " + hits.Length() + " 个 耗时:" + sw.ElapsedMilliseconds.ToString() + "毫秒</p>";
|
这样基本查询功能就OK了。写篇博客记录下,给自己加深下印象。明天有时间还得捣鼓捣鼓分词,内置分词不是很好。
代码写的很乱,还是提供个下载。(点击下载)