kibana 請求

//1.基本命令
//刪除索引
delete /test
/創建索引/
put /test
{
"settings":{
"number_of_shards":1,
"number_of_replicas":1
}
}

delete /employee
put /employee
{
"settings":{
"number_of_shards":1,
"number_of_replicas":1
}
}
/沒有則創建 有則修改/
put /employee/_doc/1
{
"name":"湯姆",
"age":30
}
/指定字段修改/
post /employee/_doc/6/_update
{
"doc":{
"age":"3"
}
}
/創建/
post /employee/_doc/6/_create/
{
"name":"兄長",
"age":1
}
/獲取索引記錄/
get /employee/_doc/2
/刪除文檔/
delete /employee/_doc/2
/查詢全部/
get /employee/_doc/_search

//使用結構化的方式創建索引
put /employee
{
"settings":{
"number_of_shards":1,
"number_of_replicas":1
},
"mappings":{
"_doc":{
"properties":{
"name":{"type":"text"},
"age":{"type":"integer"}
}
}
}
}
}
//不帶條件查詢所有記錄
get /employee/_doc/_search
{
"query":{
"match_all":{}
}
}
//分頁查詢
get /employee/_doc/_search
{
"query":{
"match_all":{}
},
"from":0,
"size":30
}
//帶關鍵字查詢
get /employee/_doc/_search
{
"query":{
"match":{"name":"兄長"}
}
}
//帶排序查詢
get /employee/_doc/_search
{
"query":{
"match":{"name":"兄長"}
},
"sort":[
{"age":{"order":"desc"}}
]
}
//帶filter 不打分_source都是0.0
get /employee/_doc/_search
{
"query":{
"bool":{
"filter":[
{"term":{"age":30}}
]}
}
}
get /employee/_doc/_search
{
"query":{
"bool":{
"filter":[
{"match":{"name":"兄"}}
]}
}
}
//帶聚合
get /employee/_doc/_search
{
"query":{
"match":{"name":"兄"}
},
"sort":[
{"age":{"order":"desc"}}
],
"aggs":{
"group_by_age":{
"terms":{"field":"age"}
}
}
}
//2.高級查詢
//新建一個索引
put /movie/_doc/1
{
"name": "Eating an apple a day & keeps the doctor away"
}
get /movie/_doc/_search
{
"query":{
"match":{
"name":"eat"
}
}
}
//使用analyze api查看分詞狀態
get /movie/_analyze
{
"field":"name",
"text": "Eating an apple a day & keeps the doctor away"
}
delete /movie
//使用結構化方式創建索引 英文分詞
put /movie
{
"settings":{
"number_of_shards":1,
"number_of_replicas":1
},
"mappings":{
"_doc":{
"properties":{
"name":{"type":"text","analyzer":"english"}
}
}
}
}
//3.類型
//text : 被分析索引的字符串類型
//keyword:不能被分析只能精確匹配的字符串類型
//date:日期類型,可以配合format一起使用
//數字類型:long、integer、short、double等
//boolean:true false
//array:["one","two"]
//object:json 嵌套
//ip類型
//geo_point:地理位置
//4.tmdb

put /movie
{
"settings":{
"number_of_shards":1,
"number_of_replicas":1
},
"mappings":{
"_doc":{
"properties":{
"title":{"type":"text","analyzer":"english"},
"tagline":{"type":"text","analyzer":"english"},
"release_date":{"type":"date","format":"8yyyy/MM/dd||yyyy/MM/d||yyyy/M/dd||yyyy/M/d"},
"popularity":{"type":"double"},
"overview":{"type":"text","analyzer":"english"},
"cast":{
"type":"object",
"properties":{
"character":{"type":"text", "analyzer":"standard"},
"name":{"type":"text", "analyzer":"standard"}
}
}
}
}
}
}

get /movie/_analyze
{
"field":"title",
"text":"basketball with cartoom aliens"
}
//搜索內容 match
get /movie/_doc/_search
{
"query":{
"match":{"title":"steve zissou"}
}
}
//搜索內容 term 不進行分詞分析直接去索引查詢
get /movie/_doc/_search
{
"query":{
"term":{"title":"steve zissou"}
}
}
//分詞后的and和or的邏輯
get /movie/_doc/_search
{
"query":{
"match":{"title":"basketball with cartoom aliens"}
}
}
//改成and
get /movie/_search
{
"query":{
"match":{
"title":{
"query":"basketball love aliens",
"operator":"and"
}
}
}
}
//最小匹配項
get /movie/_search
{
"query":{
"match":{
"title":{
"query":"basketball love aliens",
"operator":"or",
"minimum_should_match": 2
}
}
}
}
//短語查詢 查詢不做分析分詞
get /movie/_search
{
"query":{
"match_phrase":{"title":"steve zissou"}
}
}

多字段查詢

get /movie/_search
{
"query":{
"multi_match":{
"query":"basketball with cartoom aliens",
"fields":["title", "overview"]
}
}
}

評分分析

get /movie/_search
{
"explain":true,
"query":{
"multi_match":{
"query":"basketball with cartoom aliens",
"fields":["title", "overview"],
"tie_breaker": 0.3
}
}
}

優化多詞查詢

get /movie/_doc/_search
{
"query":{
"multi_match": {
"query":"basketball with cartoom aliens",
"fields":["title^10", "overview"],
"tie_breaker": 0.3
}
}
}

不同的multi_query其實是有不同的type

best_fields:默認的得分方式,取最高的分數作為對應文檔的對應分數

most_fields:考慮絕大多數(所有的)文檔的字段得分相加,獲得我們想要的結果

cross_fields :已分詞為單位計算總分 適用于詞導向的場景

get /movie/_doc/_search
{
"explain":true,
"query":{
"multi_match": {
"query":"steve zissou",
"fields":["title^10", "overview"],
"type": "best_fields"
}
}
}
get /movie/_doc/_search
{
"explain":true,
"query":{
"multi_match": {
"query":"steve zissou",
"fields":["title^10", "overview^0.3"],
"type": "most_fields"
}
}
}
get /movie/_doc/_search
{
"explain":true,
"query":{
"multi_match": {
"query":"basketball with cartoom aliens",
"fields":["title^10", "overview^0.3"],
"type": "cross_fields"
}
}
}

bool 查詢

must not 必須都是false

must 必須都是true

should 其中有一個為true即可 為true的越多則得分越高

get /movie/_doc/_search
{
"query":{
"bool":{
"should":[
{"match": {"title":"basketball with cartoom aliens"}},
{"match": {"overview":"basketball with cartoom aliens"}}
]
}
}
}

query string

方便的利用 and or not

get /movie/_doc/_search
{
"query":{
"query_string": {
"fields": ["title"],
"query": "steve OR jobs"
}
}
}

filter 過濾查詢

get /movie/_search
{
"query":{
"bool":{
"filter":{
"term":{"title":"steve"}
}
}
}
}

多條件過濾

get /movie/_search
{
"query":{
"bool":{
"filter":[
{"term":{"title":"steve"}},
{"term":{"cast.name":"gaspard"}},
{"range":{"release_date":{"lte":"2015/01/01"}}},
{"range":{"popularity":{"gte":"25"}}}
]
}

},
"sort":[
{"popularity":{"order":"desc"}}
]
}

帶match打分的filter

get /movie/_search
{
"query":{
"bool":{
"should":[
{"match":{"title":"life"}},
{"multi_match": {
"query":"basketball with cartoom aliens",
"fields":["title^10", "overview^0.3"],
"type": "cross_fields"
}
}
],
"filter":[
{"range":{"release_date":{"lte":"2020/01/01"}}},
{"range":{"popularity":{"gte":"0"}}}
]
}
}
}

自定義score計算

get /movie/_search
{
"explain":true,
"query":{
"function_score": {
"query": {
"multi_match": {
"query": "steve job",
"fields": ["title", "overview"],
"type":"most_fields"
}
},
"functions": [
{
"field_value_factor": {
"field": "popularity", //對應要處理的字段
"modifier": "log2p",
"factor": 10
}
},
{
"field_value_factor": {
"field": "popularity", //對應要處理的字段
"modifier": "log2p",
"factor": 5
}
}
],
"score_mode":"sum",
"boost_mode":"sum"
}
}
}

測試ik分詞器

get _analyze
{
"analyzer":"ik_smart",
"text":"中華人民共和國國歌"
}

最大化分詞

get _analyze
{
"analyzer":"ik_max_word",
"text":"中華人民共和國國歌"
}
get _analyze
{
"analyzer":"english",
"text":"basketball with cartoom aliens"
}

analyzer 指定的是構建索引的時候的分詞

search_analyzer 指定的是搜索關鍵字時候的分詞

最佳實踐: 構建索引的時候使用max_word,但是查詢的時候使用smartword

使用距離排序

get /shop/_search
{
"query":{
"match":{"name":"凱越"}
},
"_source":*,
"script_fields":{ //es 腳本
"distance": {
"script":{
"source": "haversin(lat,lon,doc['location'].lat,doc['location'].lon)",
"lang":"expression",
"params":{"lat":23.11,"lon":127.12}
}
}
},
"sort":[
{
"_geo_distance": { //距離計算排序
"location": {
"lat":23.11,
"lon":127.12
},
"order":"asc",
"unit":"km",
"distance_type":"arc"
}
}
]
}

使用function_score解決排序模板

get /shop/_search
{
"_source":*,
"script_fields":{ //es 腳本
"distance": {
"script":{
"source": "haversin(lat,lon,doc['location'].lat,doc['location'].lon)",
"lang":"expression",
"params":{"lat":23.11,"lon":127.12}
}
}
},
"query":{
"function_score": {
"query": {
"bool":{
"must": [
{ "match":{"name":"凱越"}},
{"term":{"seller_disabled_flag":0}}
]
}

  },
  "functions": [
    {
      "gauss":{
        "location":{
          "origin":"23.11,127.12",
          "offset":"0km",
          "scale":"100km",
          "decay":0.5
        }
      },
      "weight": 9
    },
    {
      "field_value_factor": {
        "field": "remark_score"
      },
      "weight": 0.2,
    },
    {
      "field_value_factor": {
        "field": "seller_remark_score"
      },
      "weight": 0.1
    },
    {
      "filter": { 
        "term": { "name": "*" }
      },
      "weight": 1
    }
  ]
}

}
}


//創建
put /employee2
{
"settings":{
"number_of_shards":1,
"number_of_replicas":1
},
"mappings":{
"_doc":{
"properties":{
"name":{"type":"text"},
"age":{"type":"integer"}
}
}
}
}
}
//添加字段
put /employee2/_mapping/_doc
{
"properties": {
"auditStatus": {
"type": "integer"
}
}
}
//查詢
{"_source":"*",
"script_fields":{
"distance":{
"script":{
"source": "haversin(lat,lon,doc['location'].lat,doc['location'].lon)",
"lang": "expression",
"params":{"lat":39.995125, "lon":116.474152}
}
}
},
"query": {
"function_score": {
"query":{
"bool":{
"should":[
{"match_all":{}}
],
"filter":[{"terms":{"status":[3]}},{"range":{"editTime":{"lte":"2021-12-01 09:33:53"}}}],
"minimum_should_match":1
}
},
"functions":[{"gauss":{"location":{"offset":"0km","origin":"39.995125,116.474152","scale":"500km","decay":0.5}},"weight":0},{"field_value_factor":{"field":"id","modifier":"log2p","factor":2},"weight":0},{"field_value_factor":{"field":"praiseNum","modifier":"log2p","factor":2},"weight":0},{"field_value_factor":{"field":"commentNum","modifier":"log2p","factor":2},"weight":0},{"field_value_factor":{"field":"rewardNum","modifier":"log2p","factor":2},"weight":0},{"field_value_factor":{"field":"reward","modifier":"log2p","factor":2},"weight":0},{"filter":{"match":{"categoryName":"情感"}},"weight":0},{"filter":{"term":{"topStatus":1}},"weight":50000000}],
"score_mode": "sum",
"boost_mode": "sum"
}
},
"sort": [
{
"_score":{
"order": "desc"
},
"updateTimestamp" :{
"order": "desc"
} }
],
"from":0,"size": 10}

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,517評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,087評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,521評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,493評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,207評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,603評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,624評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,813評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,364評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,110評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,305評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,874評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,532評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,953評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,209評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,033評論 3 396
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,268評論 2 375

推薦閱讀更多精彩內容