概述:

在开发网站的时候经常有要对某些内容查询的需求。此时如果基于数据库查询来做搜索功能,由于要对多个字段做模糊匹配,效率往往非常糟糕。这种情况就可以用Solr来提升搜索的效率。Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口。这里介绍下Solr的环境和配置,然后说下应用SolrNet客户端对Solr服务器的操作。

一、Solr安装

软件下载:Solr 5.0、JDK 7以上

安装jdk.。Solr直接解压完,用命令行直接可以启动。

命令行中进入server文件夹,使用如下命令启动solr服务:

在浏览器中输入如下地址:http://localhost:8983/solr/ 。能打开如下页面说明solr服务已正常启动。

Solr是基于java开发的所以需要jdk环境。下载的Solr的包里自带有jetty Web服务器。这里就是使用自带的。

二、Solr配置

新建core:

在上面打开的web界面操作即可。点击Core Admin菜单进入Core管理界面。

点击<Add Core>按钮新建一个core,如图提示需要配置文件。

所以我们到\solr-5.0.0\server\solr的路径下新建一个名称为“test”的文件夹。再到solr-5.0.0\server\solr\configsets\basic_configs文件夹下,把Conf文件夹复制到刚才新建的test文件夹下。这样就把需要的配置文件提供了,等下再介绍配置文件的配置。

再点击Add Core按钮完成Core创建。

配置Solr的Schema.xml:

一般情况下只要配置Schema文件就可以使用solr。Schema文件是用来描述Solrs索引的数据结构的。

fieldType:描述solr支持的数据类型

uniqueKey:标记solr的主键字段

field:标记solr的索引的字段

dynamicField:支持通配符的索引字段,在field中找不到的就会来匹配该字段

一般情况下要添加field节点,field和你要查询的字段对应。如图添加了title字段。

然后在uniqueKey设置主键。如图把id字段设置为主键。

三、SolrNet构建索引

下载solrnet。

建议下载地址:http://download.csdn.net/download/tp4479/4666325。下载以后自己编译。虽然从Nuget也可以下载到,但是这个版本好像有bug。

使用solr构建索引:

以下代码是向solr服务器添加一个索引数据。批量添加索引类似。

 Startup.Init<SolrDocument>("http://localhost:8983/solr/test");
var solr = ServiceLocator.Current.GetInstance<ISolrOperations<SolrDocument>>();
var doc = new SolrDocument() { Id="key1",Title="tt1"};
solr.Add(doc);
solr.Commit();

四、SolrNet查询

使用solr查询数据:

 var solr = ServiceLocator.Current.GetInstance<ISolrOperations<SolrDocument>>();
QueryOptions options = new QueryOptions();
options.Rows = ;//结果获取个数
options.Start = ;//取结果的开始位置 ,用于分页
IList<ISolrQuery> qlist = new List<ISolrQuery>();
var qfied = new SolrQueryByField("Title","tt1");
var qkey = new SolrQueryByField("Id", "key1");
qlist.Add(qfied);
qlist.Add(qkey);
var qs = new SolrMultipleCriteriaQuery(qlist, "or");//查询条件间的关系
var res2 = solr.Query(qs,options);

模糊查询:用通配符实现

var res1 = solr.Query(new SolrQuery("Title:*a1*"), options);

总结

到这里就简要的介绍了用.net客户端SolrNet操作Solr的过程。希望能让没接触过的朋友对solr的应用有个总体的概念。

.net中运用solr提升搜索效率(入门)的更多相关文章

  1. 在ssh中利用Solr服务建立的界面化站内搜索---solr2

         继上次匆匆搭建起结合solr和nutch的所谓站内搜索引擎之后,虽当时心中兴奋不已,可是看了看百度,再只能看看我的控制台的打印出每个索引项的几行文字,哦,好像差距还是有点大……        ...

  2. 在ssh中利用Solr服务建立的界面化站内搜索

         继上次匆匆搭建起结合solr和nutch的所谓站内搜索引擎之后,虽当时心中兴奋不已,可是看了看百度,再只能看看我的控制台的打印出每个索引项的几行文字,哦,好像差距还是有点大……      简 ...

  3. 使用Elasticsearch中的copy_to来提高搜索效率

    在今天的这个教程中,我们来着重讲解一下如何使用Elasticsearch中的copy来提高搜索的效率.比如在我们的搜索中,经常我们会遇到如下的文档: { "user" : &quo ...

  4. C#中的线程(一)入门

    C#中的线程(一)入门   Keywords:C# 线程Source:http://www.albahari.com/threading/Author: Joe AlbahariTranslator: ...

  5. atitit.提升开发效率---使用服务器控件生命周期 asp.net 11个阶段 java jsf 的6个阶段比较

    atitit.提升开发效率---使用服务器控件生命周期  asp.net 11个阶段  java jsf 的6个阶段比较 如下列举了服务器控件生命周期所要经历的11个阶段. (1)初始化-- --在此 ...

  6. Atitit. 提升开发效率与质量DSL ( 3) ----实现DSL的方式总结

    Atitit. 提升开发效率与质量DSL ( 3) ----实现DSL的方式总结 1. 管道抽象 1 2. 层次结构抽象(json,xml etc) 1 3. 异步抽象promise 1 4. Ide ...

  7. atitit.提升开发效率---MDA 软件开发方式的革命(3)----自动化建表

    atitit.提升开发效率---MDA 软件开发方式的革命(3)----自动化建表 1. 建模在后自动建表 1 1. 传统上,需要首先建表,在业务编码.. 1 2. 模型驱动建表---更多简化法是在建 ...

  8. atitit.提升开发效率---mda 软件开发方式的革命--(2)

    atitit.提升开发效率---mda 软件开发方式的革命--(2) 1. 一个完整的MDA规范包含: 1 2. 一个完整的MDA应用程序包含: 1 3. MDA能够带来的最大的三个好处是什么? 2 ...

  9. atitit.提升开发效率---mda 软件开发方式的革命

    atitit.提升开发效率---mda 软件开发方式的革命 1. 软件开发方式的革命开发工具的抽象层次将再次提升 1 2. 应用框架和其实现相分离 2 3. 目前的问题模型和代码不同步 2 4. MD ...

随机推荐

  1. SQL Server 数据库基础编程

    Ø Go批处理语句 用于同时执行多个语句 Ø 使用.切换数据库 use master go     Ø 创建.删除数据库   方法1.   --判断是否存在该数据库,存在就删除 if (exists ...

  2. PHP生成静态页面的方法

          在PHP网站开发中为了网站推广和SEO等需要,需要对网站进行全站或局部静态化处理,PHP生成静态HTML页面有多种方法,比如利用PHP模板.缓存 等实现页面静态化,今天就以PHP实例教程形 ...

  3. WEB跨域的实现

    同源策略/SOP(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,浏览器很容易受到XSS.CSFR等攻击(可以参考我的这篇文章). SOP要求 ...

  4. Linux下对于inode的理解

    0x01 什么是inode 文件存储在硬盘上,硬盘的最小存储单位叫做“扇区”(Sector),每个扇区储存512字节: 操作系统读取硬盘时,不会一个个扇区地读取,这样效率低,而是一次性连续读取多个扇区 ...

  5. 001MSP430概述

    1.MSP430系列单片机的特点 (1)超低功耗:生来就是为超低功耗设计的,从CPU内核结构到片上外设,以及整个芯片的生产制造都是本着超低功耗的原则来进行的,所以是一款实实在在的超低功耗单片机: (2 ...

  6. Python之路【第九篇】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

    Python之路[第九篇]:Python操作 RabbitMQ.Redis.Memcache.SQLAlchemy   Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用 ...

  7. 用Lambda表达式操作List集合

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...

  8. MongoDB的主要特性概述

    一.文档数据模型 文档是一组属性名和属性的集合.相较于关系数据库复杂的规范化,面向文档的数据模型很容易以聚合的形式来表示数据.文档采用无Schema的形式,这种做法带来了一定的优势:首先,由应用程序, ...

  9. (转)最强Android模拟器genymotion的安装与配置

    Android开发人员都知道,原生的模拟器启动比较慢,操作起来也不流畅,还会出现莫名的问题.当然很多人都会选择直接使用android手机来开发,但是有时候需要在投影仪上演示程序的时候手机不太好做到吧. ...

  10. 用web查看hadoop运行状态

    转载--http://www.weixuehao.com/archives/621 我们安装完hadoop,下面我们从视觉上看看hadoop怎么玩的. 我们可以在win7系统上,通过web界面,在浏览 ...