search_queries_match.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. // Copyright 2012-2015 Oliver Eilhard. All rights reserved.
  2. // Use of this source code is governed by a MIT-license.
  3. // See http://olivere.mit-license.org/license.txt for details.
  4. package elastic
  5. // MatchQuery is a family of queries that accept text/numerics/dates,
  6. // analyzes it, and constructs a query out of it. For more details,
  7. // see http://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-match-query.html.
  8. //
  9. // To create a new MatchQuery, use NewMatchQuery. To create specific types
  10. // of queries, e.g. a match_phrase query, use NewMatchQuery(...).Type("phrase"),
  11. // or use one of the shortcuts like NewMatchPhraseQuery(...).
  12. type MatchQuery struct {
  13. Query
  14. name string
  15. value interface{}
  16. matchQueryType string // boolean, phrase, phrase_prefix
  17. operator string // or / and
  18. analyzer string
  19. boost *float32
  20. slop *int
  21. fuzziness string
  22. prefixLength *int
  23. maxExpansions *int
  24. minimumShouldMatch string
  25. rewrite string
  26. fuzzyRewrite string
  27. lenient *bool
  28. fuzzyTranspositions *bool
  29. zeroTermsQuery string
  30. cutoffFrequency *float32
  31. queryName string
  32. }
  33. // NewMatchQuery creates a new MatchQuery.
  34. func NewMatchQuery(name string, value interface{}) MatchQuery {
  35. q := MatchQuery{name: name, value: value}
  36. return q
  37. }
  38. // NewMatchPhraseQuery creates a new MatchQuery with type phrase.
  39. func NewMatchPhraseQuery(name string, value interface{}) MatchQuery {
  40. q := MatchQuery{name: name, value: value, matchQueryType: "phrase"}
  41. return q
  42. }
  43. // NewMatchPhrasePrefixQuery creates a new MatchQuery with type phrase_prefix.
  44. func NewMatchPhrasePrefixQuery(name string, value interface{}) MatchQuery {
  45. q := MatchQuery{name: name, value: value, matchQueryType: "phrase_prefix"}
  46. return q
  47. }
  48. // Type can be "boolean", "phrase", or "phrase_prefix".
  49. func (q MatchQuery) Type(matchQueryType string) MatchQuery {
  50. q.matchQueryType = matchQueryType
  51. return q
  52. }
  53. func (q MatchQuery) Operator(operator string) MatchQuery {
  54. q.operator = operator
  55. return q
  56. }
  57. func (q MatchQuery) Analyzer(analyzer string) MatchQuery {
  58. q.analyzer = analyzer
  59. return q
  60. }
  61. func (q MatchQuery) Boost(boost float32) MatchQuery {
  62. q.boost = &boost
  63. return q
  64. }
  65. func (q MatchQuery) Slop(slop int) MatchQuery {
  66. q.slop = &slop
  67. return q
  68. }
  69. func (q MatchQuery) Fuzziness(fuzziness string) MatchQuery {
  70. q.fuzziness = fuzziness
  71. return q
  72. }
  73. func (q MatchQuery) PrefixLength(prefixLength int) MatchQuery {
  74. q.prefixLength = &prefixLength
  75. return q
  76. }
  77. func (q MatchQuery) MaxExpansions(maxExpansions int) MatchQuery {
  78. q.maxExpansions = &maxExpansions
  79. return q
  80. }
  81. func (q MatchQuery) MinimumShouldMatch(minimumShouldMatch string) MatchQuery {
  82. q.minimumShouldMatch = minimumShouldMatch
  83. return q
  84. }
  85. func (q MatchQuery) Rewrite(rewrite string) MatchQuery {
  86. q.rewrite = rewrite
  87. return q
  88. }
  89. func (q MatchQuery) FuzzyRewrite(fuzzyRewrite string) MatchQuery {
  90. q.fuzzyRewrite = fuzzyRewrite
  91. return q
  92. }
  93. func (q MatchQuery) Lenient(lenient bool) MatchQuery {
  94. q.lenient = &lenient
  95. return q
  96. }
  97. func (q MatchQuery) FuzzyTranspositions(fuzzyTranspositions bool) MatchQuery {
  98. q.fuzzyTranspositions = &fuzzyTranspositions
  99. return q
  100. }
  101. // ZeroTermsQuery can be "all" or "none".
  102. func (q MatchQuery) ZeroTermsQuery(zeroTermsQuery string) MatchQuery {
  103. q.zeroTermsQuery = zeroTermsQuery
  104. return q
  105. }
  106. func (q MatchQuery) CutoffFrequency(cutoff float32) MatchQuery {
  107. q.cutoffFrequency = &cutoff
  108. return q
  109. }
  110. func (q MatchQuery) QueryName(queryName string) MatchQuery {
  111. q.queryName = queryName
  112. return q
  113. }
  114. func (q MatchQuery) Source() interface{} {
  115. // {"match":{"name":{"query":"value","type":"boolean/phrase"}}}
  116. source := make(map[string]interface{})
  117. match := make(map[string]interface{})
  118. source["match"] = match
  119. query := make(map[string]interface{})
  120. match[q.name] = query
  121. query["query"] = q.value
  122. if q.matchQueryType != "" {
  123. query["type"] = q.matchQueryType
  124. }
  125. if q.operator != "" {
  126. query["operator"] = q.operator
  127. }
  128. if q.boost != nil {
  129. query["boost"] = *q.boost
  130. }
  131. if q.slop != nil {
  132. query["slop"] = *q.slop
  133. }
  134. if q.fuzziness != "" {
  135. query["fuzziness"] = q.fuzziness
  136. }
  137. if q.prefixLength != nil {
  138. query["prefix_length"] = *q.prefixLength
  139. }
  140. if q.maxExpansions != nil {
  141. query["max_expansions"] = *q.maxExpansions
  142. }
  143. if q.minimumShouldMatch != "" {
  144. query["minimum_should_match"] = q.minimumShouldMatch
  145. }
  146. if q.rewrite != "" {
  147. query["rewrite"] = q.rewrite
  148. }
  149. if q.fuzzyRewrite != "" {
  150. query["fuzzy_rewrite"] = q.fuzzyRewrite
  151. }
  152. if q.lenient != nil {
  153. query["lenient"] = *q.lenient
  154. }
  155. if q.fuzzyTranspositions != nil {
  156. query["fuzzy_transpositions"] = *q.fuzzyTranspositions
  157. }
  158. if q.zeroTermsQuery != "" {
  159. query["zero_terms_query"] = q.zeroTermsQuery
  160. }
  161. if q.cutoffFrequency != nil {
  162. query["cutoff_frequency"] = q.cutoffFrequency
  163. }
  164. if q.queryName != "" {
  165. query["_name"] = q.queryName
  166. }
  167. return source
  168. }