LinqToHubble介绍及简单使用步骤——LinqToHubble是对HubbleDotnet的封装
或许你还你知道HubbleDotnet,下面简单对HubbleDotnet坐下介绍。
HubbleDotNet是由盘古分词作者——eaglet 开发的一个基于.net framework 的开源免费的全文搜索数据库组件。开源协议是 Apache 2.0。HubbleDotNet提供了基于SQL的全文检索接口,使用者只需会操作SQL,就可以很快学会使用HubbleDotNet进行全文检索。
HubbleDotNet可以实现全文索引和查询、多域检索和排序、分组统计、消重、分类、聚类、多表关联查询等等一系列全文检索和数据挖掘功能。 HubbleDotNet提供开放的数据库适配器接口,可以和各种数据库完美整合,为各种数据库系统附加全文检索和数据挖掘功能。
HubbleDotNet设计了较为完善的并发控制程序,数据的增删改查可以多线程同时并发进行,没有任何冲突。HubbleDotNet还进行了缓存和内存管理设计,可以帮助用户最大限度的提高查询的效率。HubbleDotNet力争在未来的几年内超过Lucene.net成为.net开发环境中最受欢迎的全文检索组件。
项目源代码地址:http://hubbledotnet.codeplex.com/
如果你想学习实用HubbleDotNet,请看作者的博客介绍:HubbleDotNet开源全文搜索数据库项目--技术详解
-------------------------------------------------------------------------邪恶的分割线------------------------------------------------------------------------------
下面讲述的是 scott (QQ昵称) 对HubbleDotNet的进一步开发的 LinqToHubble。(最近更新:2014年9月12日,更新修复2个bug)
1、首先下载dll文件,并添加引用。
1).下载地址1:https://files.cnblogs.com/moretry/linq2hubble.zip
2).下载地址2: http://download.csdn.net/detail/jinliang99/7910075
3).dll文件请全部添加引用,Hubble.net 的 dll为最新版本编译的。
4).请将dictionaries 盘古分词字典文件夹放到程序运行根目录,或者包含着在项目中(较新则复制),其实是编译器帮我们复制到程序运行根目录下的。
2、在程序的配置文件内添加hubbledotnet的section,配置文件如下:
<configuration> <configSections> <section name="hubbledotnet" requirePermission="false" type="ZY.Search.Pro.Core.ConfigInfo, ZY.Search.Pro" ></section> </configSections> <hubbledotnet> <connectionString>server=your connectionstring;uid=hubble username;pwd=hubble password;database=hubble database</connectionString> <fragmentSize>200</fragmentSize> <cacheTimeout>1000</cacheTimeout> <commandTimeout>100</commandTimeout> <highlighterFormatter> <font color="red">,</font> </highlighterFormatter> </hubbledotnet> </configuration>
注意事项:configSections 节点要在 configuration 的第一节点。 连接字符串自己替换下,没有用户名和密码的可以删除 uid=hubble username;pwd=hubble password;
3、构造自己的实体,根据自己的hubble数据表构造自己的model示例,需要添加system.data.linq.dll的引用。
using System.Data.Linq.Mapping; [Table(Name = "Member")]//hubbledotnet服务器里的表名称 public class Member { [Column]//缺省为属性名 public string Id { get; set; } [Column(Name = "Name^10")]//字段权重 10 默认1 public string Name { get; set; } [Column(Name = "Description^5")]//字段权重 5 默认1 public string Description { get; set; } }
4、根据具体业务编写自己的代码:
static void Main() { string keyWords = "关键词"; DatabaseDataContext dc = new DatabaseDataContext(); var result = dc.GetTable < Member > ().Where(x = > x.Name.Match(keyWords) || x.Description.Match(keyWords)); # region //result = from item in result // where item.Name.Contains(keywords, true) //也支持这种写法 // select item; # endregion //region 统计总数 //var count = result.Count(); foreach(var v in result.AsHighlight < Member > (keywords)) //高亮这样用AsHighlight,不高亮您随便 //foreach(var v in result)不高亮 { Console.WriteLine(v.Name); } Console.ReadKey(); }
5、哦,不好意思,作者说没有第五步了。此文为转载,原作者的博客地址:http://www.itrefer.com/index.php/archives/15。。。。
是不是很简单啊,我也是初学者,我感觉很快就能上手了。
Hubble.net 1群: 128951966 Hubble.net 2群:161508409 欢迎学习Hubble.net的来一起交流学习。