搜索功能设计

我们的搜索功能和界面是在solr自带示例基础上修改完成的,在此基础上,我们基本拥有示例所有功能并美化了界面。目前我们所完成的搜索功能有: (除特意指出的,其他都在solrconfig.xml中设置)

  • 关键词搜索
  • 高级搜索
  • 分组统计
  • 分页显示
  • 搜索结果高亮
  • 拼写检查、自动纠错
  • 搜索建议、自动补全
  • 相似匹配

关键词搜索

关键词搜索就是在搜索框中输入查询词,搜索结果按要求顺序显示。排序规则权重设置如图:

权重.PNG

高级搜索

由于时间有限,我们的高级搜索功能暂时是在关键词搜索的基础上,以乐器种类作为过滤器,为用户筛选出更明确的结果。

高级搜索.PNG

分组统计

我们实现分组统计的方法是使用了Solr的Facet组件, Facet组件是Solr默认集成的一个组件,可以给用户提供更友好的搜索体验,在搜索关键字的同时,能够按照Facet的字段进行分组并统计。

分类.PNG
  • Facet设置
  • facet=on:启用facet组件
  • facet.missing :默认为””,如果设置为true或者on,那么将统计那些该Facet字段值为null的记录。
  • facet.field:设置需要进行facet查询的字段
  • facet.query:利用类似于filter query的语法提供了更为灵活的Facet。通过facet.query参数,可以对任意字段进行筛选。
  • facet.mincount:限制了Facet字段值的最小count,默认为0。合理设置该参数可以将用户的关注点集中在少数比较热门的领域。
分组.PNG

分页显示

对搜索结果分页显示,保证每次查询都只需返回整个搜索结果中的一个很小的集合,从而提高系统的响应速度。

分页.PNG

由于搜索结果中图片较多且尺寸不同,我们采用小图显示,鼠标悬浮显示大图,简化界面,便于浏览。

大图.png

搜索结果高亮

在结果显示时,对用户输入的检索词粗体加黑高亮显示,辅助用户进行浏览查询与结果筛选。

  • 输入检索词“民歌”,效果如图
高亮.png
  • 设置
  • hl=on:启用组件
  • hl.fl :想要高亮处理的字段
  • hl.simple.pre和hl.simple.post:设置前后标签,不用两个参数的话,默认的是在高亮内容两边加<em></em>
    高亮设置.png

拼写检查、自动纠错

设计拼写检查和纠错机制,在用户出现拼写错误时自动根据该词语在索引中是否存在而做出相应处理,若错误则返回错误提醒,并提示正确搜索词。

  • 效果
拼写检查.png
  • /browserequestHandler中启用spellcheck
spell.png
  • 设置spellchecksearchComponent
    <searchComponent name="spellcheck" class="solr.SpellCheckComponent">
    <str name="queryAnalyzerFieldType">string</str>
    <lst name="spellchecker">
    <str name="name">default</str>
    <str name="field">title</str>
    <str name="classname">solr.DirectSolrSpellChecker</str>
    <str name="distanceMeasure">internal</str>
    <float name="accuracy">0.5</float>
    <int name="maxEdits">2</int>
    <int name="minPrefix">1</int>
    <int name="maxInspections">5</int>
    <int name="minQueryLength">2</int>
    <float name="maxQueryFrequency">0.0000001</float>
    </lst>
    </searchComponent>

  • 设置/spellrequestHandler
    <requestHandler name="/spell" class="solr.SearchHandler" startup="lazy">
    <lst name="defaults">

    <str name="spellcheck.dictionary">default</str>
    <str name="spellcheck">on</str>
    <str name="spellcheck.extendedResults">true</str>
    <str name="spellcheck.count">10</str>
    <str name="spellcheck.alternativeTermCount">5</str>
    <str name="spellcheck.maxResultsForSuggest">5</str>
    <str name="spellcheck.collate">true</str>
    <str name="spellcheck.collateExtendedResults">true</str>
    <str name="spellcheck.maxCollationTries">10</str>
    <str name="spellcheck.maxCollations">5</str>
    </lst>
    <arr name="last-components">
    <str>spellcheck</str>
    </arr>
    </requestHandler>

搜索建议、自动补全

根据用户输入,从系统索引文件中的文档内容匹配出相应的terms,并实时在输入框下方显示出来,节省用户检索时间,降低用户输入错误查询词的几率。

  • 效果显示
建议.png
  • 设置suggestsearchComponent
    <searchComponent name="suggest" class="solr.SuggestComponent">
    <lst name="suggester">
    <str name="name">mySuggester</str>
    <str name="field">title</str>
    <str name="lookupImpl">FuzzyLookupFactory</str>
    <str name="dictionaryImpl">FileDictionaryFactory</str>
    <str name="suggestAnalyzerFieldType">textComplex</str>
    <str name="buildOnStartup">false</str>
    </lst>
    </searchComponent>
  • 设置/suggestrequestHandler
    <requestHandler name="/suggest" class="solr.SearchHandler" startup="lazy" >
    <lst name="defaults">
    <str name="suggest.dictionary">mySuggester</str>
    <str name="suggest">true</str>
    <str name="suggest.count">10</str>
    </lst>
    <arr name="components">
    <str>suggest</str>
    </arr>
    </requestHandler>
  • 修改suggest.vmhead.vm中的参数,改为自己设置的field name
suggest.png
head.png
  • head.vm中我们可以看到引用了jquery autocomplete.js和对应的库。如果设置完后没有效果,可以用浏览器开发者工具查看是否有这个jquery-1.7.2.min.js这个资源,若没有,检查一下路径。
autocomplete.png

相似匹配

Solr 使用 MoreLikeThisComponent(MLT)和 MoreLikeThisHandler 实现了一样的功能。MLT 是与标准 SolrRequestHandler 集成在一起的;MoreLikeThisHandler 与 MLT 结合在一起,并添加了一些其他选项,但它要求发布一个单一的请求。

  • 效果显示
MLT.PNG
  • solrconfig.xml中设置
  • mlt.qf:权重设置,结果经过计算按顺序返回。
  • mlt.fl:用于创建 MLT 查询的字段。
  • mlt.count:可选。每一个结果要检索的相似文档数。


    mlt设置.PNG
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容