data:image/s3,"s3://crabby-images/5213a/5213adb6da18e256d43d6941370cafeff574bda0" alt="ショコラ"
AWS OpenSearchServerlessの使い方
https://aws.amazon.com/jp/blogs/news/elasticsearch-tutorial-a-quick-start-guide/
を参照してメモります。
インデックス・・・テーブル
PUT、POST・・・UPSERT
数値の比較:gte(<=)、gt(<)、lte(>=)、lt(>)
data:image/s3,"s3://crabby-images/2512f/2512fe90da35022677d8d22f56767bdd7b37afc9" alt="もっさん先輩"
▼IDを指定する場合は、PUT を使ってインサート、アップデートする。
PUT /vegetables/_doc/1
{
"name":"carrot",
"color":"orange"
}
data:image/s3,"s3://crabby-images/6c953/6c953f32eb9b8115afc2ffc096f046927a28112f" alt=""
↑最初1発目のPUTでは”result”が”created”、”_version”が”1″。2回目のPUTでは”result”が”updated”、”_version”が”2″になります。
▼IDを指定しない場合は、POST を使ってインサート、アップデートする。
POST /vegetables/_doc
{
"name":"キュウリ",
"color":"緑"
}
※POST /vegetables/_doc/ だと「Request failed to get to the server (status code: 404)」のエラーになる。
data:image/s3,"s3://crabby-images/3b1e9/3b1e98ea10f8bf3ddad01b00de1da6de5ca8bc98" alt=""
▼GET /vegetables/ を全て取得する。
GET /vegetables/_search
{
"query": {
"match_all": {}
}
}
data:image/s3,"s3://crabby-images/3628d/3628db039f27424e569ad159ee831d11b1414e1c" alt=""
▼取得するサイズをしていする。ようするにLIMIT。
GET /vegetables/_search
{
"query": {
"match_all": {}
},
"size":3
}
▼GET /vegetables/_doc/1 を取得する。
GET /vegetables/_doc/1
data:image/s3,"s3://crabby-images/4cfff/4cfffbf5c2f2e71775dc2993f34069808d92bbf2" alt=""
▼GET /vegetables/_doc/RDdLpJMBQzhePOqbMB0c を取得する。
GET /vegetables/_doc/RDdLpJMBQzhePOqbMB0c
data:image/s3,"s3://crabby-images/ec083/ec08350b8de75ca78243f4e2e9bbc82f604b2c3f" alt=""
▼項目名で値が一致するものを検索する。
GET /vegetables/_search
{
"query" : {
"term": { "name": "carrot" }
}
}
data:image/s3,"s3://crabby-images/f65e6/f65e6f146ad2c4da8d0c12600e18f6cfaf928d3a" alt=""
▼インデックスを一覧表示する。
GET /_cat/indices
▼インデックスを削除する。
DELETE /vegetables
data:image/s3,"s3://crabby-images/b4f94/b4f947639155917df8b070c91c31642e441ce129" alt=""
▼ソートするにはインデックスを作成する。
型を定義している。
DELETE /vegetables
PUT /vegetables
{
"mappings":{
"properties":{
"name":{
"type":"text"
},
"color":{
"type":"keyword"
},
"classification":{
"type":"keyword"
}
}
}
}
POST /_bulk
{ "create" : { "_index" : "vegetables", "_id" : "7" } }
{ "name":"kale", "color":"green", "classification":"leafy-green" }
{ "create" : { "_index" : "vegetables", "_id" : "8" } }
{ "name":"spinach", "color":"green", "classification":"leafy-green" }
{ "create" : { "_index" : "vegetables", "_id" : "9" } }
{ "name":"arugula", "color":"green", "classification":"leafy-green" }
{ "create" : { "_index" : "vegetables", "_id" : "10" } }
{ "name":"endive", "color":"green", "classification":"leafy-green" }
{ "create" : { "_index" : "vegetables", "_id" : "11" } }
{ "name":"lettuce", "color":"green", "classification":"leafy-green" }
{ "create" : { "_index" : "vegetables", "_id" : "12" } }
{ "name":"fruit", "color":"green", "classification":"leafy-green" }
{ "create" : { "_index" : "vegetables", "_id" : "13" } }
{ "name":"kiwi fruit", "color":"green", "classification":"leafy-green" }
ソート
GET /vegetables/_search
{
"query" : {
"term": { "color": "green" }
},
"sort" : [{
"classification": {
"order": "asc"
}}
]
}
スコア順にソート
GET /vegetables/_search
{
"query" : {
"term": { "name": "fruit" }
},
"sort" : "_score"
}
テキスト(文字列を単語分けしない)を検索する。
GET /vegetables/_search
{
"query" : {
"match": { "name": "fruit" }
},
"sort" : "_score"
}
キーワード(文字列を単語分けしない)を検索する。
GET /vegetables/_search
{
"query" : {
"wildcard": { "name": "*end*" }
},
"sort" : "_score"
}
▼数値の比較
型を定義している。
DELETE /vegetables
PUT /vegetables
{
"mappings":{
"properties":{
"name":{
"type":"text"
},
"color":{
"type":"keyword"
},
"classification":{
"type":"keyword"
},
"price":{
"type":"integer"
}
}
}
}
POST /_bulk
{ "create" : { "_index" : "vegetables", "_id" : "7" } }
{ "name":"kale", "color":"green", "classification":"leafy-green","price":"100" }
{ "create" : { "_index" : "vegetables", "_id" : "8" } }
{ "name":"spinach", "color":"green", "classification":"leafy-green","price":"200" }
{ "create" : { "_index" : "vegetables", "_id" : "9" } }
{ "name":"arugula", "color":"green", "classification":"leafy-green","price":"300" }
{ "create" : { "_index" : "vegetables", "_id" : "10" } }
{ "name":"endive", "color":"green", "classification":"leafy-green","price":"400" }
{ "create" : { "_index" : "vegetables", "_id" : "11" } }
{ "name":"lettuce", "color":"green", "classification":"leafy-green","price":"500" }
{ "create" : { "_index" : "vegetables", "_id" : "12" } }
{ "name":"fruit", "color":"green", "classification":"leafy-green","price":"600" }
{ "create" : { "_index" : "vegetables", "_id" : "13" } }
{ "name":"kiwi fruit", "color":"green", "classification":"leafy-green","price":"700" }
GET /vegetables/_search
{
"query": {
"range":{
"price":{
"gte": 500
}
}
},
"sort" : "price"
}
data:image/s3,"s3://crabby-images/27858/278581f909ff2628c235e8a7ee55f850eb006ef3" alt=""
以上