常用的查询规则
-
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,ShortDescription
或Name 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查询优化
- 为提高查询速度有可以利用几种cache来优化查询速度,分别是
fieldValueCache,queryResultCache,documentCache,filtercache
. - q改为fq
- 热点数据
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 从这个小时开始