Solr使用

在这里插入图片描述

常用的查询规则

  • q - 查询字符串,这个是必须的。如果查询所有*:*,根据指定字段查询(name:张三 AND address:北京)

  • fq -过虑查询,作用:在q查询符合结果中同时是fq查询符合的

  • fl - 指定返回那些字段内容,用逗号或空格分隔多个。

  • start - 返回第一条记录在完整找到结果中的偏移位置,0开始,一般分页用。

  • rows - 指定返回结果最多有多少条记录,配合start来实现分页。

  • sort - 排序。示例:(score desc, price asc)表示先 “score” 降序, 再 “price” 升序,默认是相关性降序。

  • wt - (writer type)指定输出格式,可以有 xml, json, php, phps。

  • fl - 表示索引显示那些field( *表示所有field,如果想查询指定字段用逗号或空格隔开(如:Name,SKU,ShortDescriptionName SKU ShortDescription【注:字段是严格区分大小写】))

  • q.op - 表示q 中 查询语句的 各条件的逻辑操作 AND(与) OR(或)

  • hl - 是否高亮 ,如hl=true

    • hl.fl - 高亮field ,hl.fl=Name,SKU
    • hl.simple.pre 高亮前面的格式
    • hl.simple.post - 高亮后面的格式
    • facet - 是否启动统计
    • facet.field - 统计field

Solr运算符

  • “:” 指定字段查指定值,如返回所有值 :
  • “?” 表示单个任意字符的通配
  • “” 表示多个任意字符的通配(不能在检索的项开始使用或者?符号)
  • “~” 表示模糊检索,如检索拼写类似于”roam”的项这样写:roam将找到形如foam和roams的单词;roam0.8,检索返回相似度在0.8以上的记录。
  • 邻近检索,如检索相隔10个单词的”apache”和”jakarta”,”jakarta apache”~10
  • “^” 控制相关度检索,如检索jakarta apache,同时希望去让”jakarta”的相关度更加好,那么在其后加上””符号和增量值,即jakarta4 apache
  • 布尔操作符AND、||、OR、&&、NOT、!、- (排除操作符不能单独与项使用构成查询)
    “+” 存在操作符,要求符号”+”后的项必须在文档相应的域中存在
  • ( ) 用于构成子查询
  • [] 包含范围检索,如检索某时间段记录,包含头尾,date:[200707 TO 200710]
  • {} 不包含范围检索,如检索某时间段记录,不包含头尾date:{200707 TO 200710}
  • / 转义操作符,特殊字符包括+ - && || ! ( ) { } [ ] ^ ” ~ * ? : /
示例:

“+”和”-“表示对单个查询单元的修饰,and 、or 、 not 是对两个查询单元是否做交集或者做差集还是取反的操作符号:

  • 比如:AB:china +AB:america 表示AB:china忽略不计可有可无,必须满足第二个条件才是对的,而不是你所认为的必须满足这两个搜索条件,
  • 如果输入:AB:china AND AB:america,是两个条件同时满足,即+AB:china AND +AB:america或+AB:china +AB:america
    总而言之,查询语法: 修饰符 字段名:查询关键词 AND/OR/NOT 修饰符 字段名:查询关键词

查询结果比较
qs = 'author:(6)'; fqs = '+is_online:true' # 855条
fq = "author:(6) AND +is_online:true" # 855条
fq = "author:(6) +is_online:true" # 6921355条
fq = "+author:(6) +is_online:true" # 855条

solr查询优化

  1. 为提高查询速度有可以利用几种cache来优化查询速度,分别是fieldValueCache,queryResultCache,documentCache,filtercache.
  2. q改为fq
  3. 热点数据

Solr中的日期有很严格的格式限制:YYYY-MM-DDThh:mm:ssZ

Solr服务中默认使用的是UTC时间, 而中国本地时间为东八时区, 即比UTC标准时间多8小时.

时间区间表示

  • 2017-01 2017年整个1月
  • 2017-01T13 2017年整个1月每天13:00到14:00
  • [2017-01-01 TO 2017-01-22] 2017年1月1号到22号
  • [2017 TO 2017-01-22] 2017年1月1号到22号
  • [ * TO 2017-01-22] 2017年1月22号之前
  • +create_time:[NOW-3DAY TO NOW] 前三天的数据。

计算时间

Solr支持一些简单的数学计算,并且内建了一些表达式

  • NOW 当前时间
  • NOW+2MONTHS 之后的两个月时间内
  • NOW-1DAY 一天前
  • NOW/HOUR 从这个小时开始
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值