Python連線es筆記四之建立和刪除操作

Hunter發表於2023-04-26
本文首發於公眾號:Hunter後端
原文連結:Python連線es筆記四之建立和刪除操作

這一篇筆記介紹一下索引和資料的建立和刪除。

其實對於索引來說,如果可以接觸到 kibana 的話,可以很方便的在介面進行操作,這裡簡單介紹一下如何使用程式碼來操作索引的建立和刪除。

索引的建立和刪除操作

使用的還是 es 的連線:

from elasticsearch_dsl import connections


connections.configure(
    default={"hosts": "localhost:9200"},
)

conn = connections.connections.get_connection("default")

建立索引

index_name = "test_create"
conn.indices.create(index_name)

檢測索引是否存在

print(conn.indices.exists(index_name))

返回的是一個布林型資料。

刪除索引

conn.indices.delete(index_name)

資料的建立和刪除

建立單條資料

還是預設使用剛剛建立的索引 test_create,我們需要往裡面加入一條資料,示例如下:

index_name = "test_create"

conn.index(
    index=index_name,
    id=1,
    body={
        "name": "李白"
    }
)

這樣就往裡面寫入了一條 id=1 的資料,如果不指定 id 引數,系統會為我們自動分配一個 id:

conn.index(
    index=index_name,
    body={
        "name": "李白"
    }
)

這種建立方式也是允許的。

批次建立資料

這裡用到在批次更新時候的使用過的 elasticsearch.helpers 函式。

示例如下:

action_1 = {
    "_op_type": "index",
    "_index": "test_create",
    "doc": {"age": 20, "name": "楊過", "address": "終南山"},
}

action_2 = {
    "_op_type": "index",
    "_index": "test_create",
    "doc": {"age": 21, "name": "郭靖", "address": "桃花島"},
}

action_list = [action_1, action_2]
helpers.bulk(conn, actions=action_list)

在這裡,因為是建立資料,所以 _op_type 的值為 index,剩下的使用方法和之前更新的操作一致。

刪除操作

刪除操作在第一篇筆記介紹查詢資料的時候帶過一筆,就是透過 Search() 方法加入條件後,不執行 execute(),而是執行 delete() 函式進行刪除:

s = Search(using="default").index("exam").query("match", name="張三丰")
s.delete()

還有一種 es 連線直接操作的 delete_by_query() 函式,示例如下:

conn = connections.connections.get_connection("default")

q1 = ES_Q("term", name="楊過")

conn.delete_by_query(
    index="exam",
    body={
        "query": q1
    }
)

如果想獲取更多後端相關文章,可掃碼關注閱讀:

image.png

相關文章