JSCODE Logo
프로그래밍 과외블로그후기멘토진
회사명 : JSCODE대표 : 박재성사업자 등록번호 : 244-22-01557통신판매업 : 제 2023-인천미추홀-0381 호
학원 명칭 : 제이에스코드(JSCODE)원격학원학원설립ㆍ운영 등록번호 : 제6063호

서울특별시 구로구 경인로 20가길 11(오류동, 아델리아)

Copyright ⓒ 2025 JSCODE - 최상위 현업 개발자들의 프로그래밍 교육 All rights reserved.

이용약관개인정보처리방침
← 블로그 목록으로 돌아가기

도큐먼트 저장, 조회, 수정, 삭제하기

JSCODE 박재성
JSCODE 박재성
2025-12-06
author
JSCODE 박재성
category
Elasticsearch
createdAt
Dec 6, 2025
series
실전에서 바로 써먹는 Elasticsearch 입문 (검색 최적화편)
slug
crud-documents
type
post
updatedAt
Dec 6, 2025 04:48 AM

✅ 도큐먼트 저장

  1. id를 자동으로 생성해서 저장
    1. # 도큐먼트 저장 (id 자동 생성) # POST /{인덱스명}/_doc POST /users/_doc { "name": "Jaeseong", "age": 20, "is_active": true } # 잘 저장됐는 지 확인하기 GET /users/_search
 
  1. id를 직접 지정해서 저장
    1. # 도큐먼트 저장 (id 직접 지정) # POST /{인덱스명}/_create/{id} POST /users/_create/1 { "name": "jscode", "age": 30, "is_active": true } # 잘 저장됐는 지 확인하기 GET /users/_search # 이미 존재하는 id로 데이터 저장하면 어떻게 되는 지 확인하기 POST /users/_create/1 { "name": "jscode", "age": 30, "is_active": true }
       
  1. id를 직접 지정해서 저장 (이미 id가 존재한다면 데이터 덮어씌움) = UPSERT
    1. # 도큐먼트 저장 및 업데이트 # PUT /{인덱스명}/_doc/{id} PUT /users/_doc/2 { "name": "jason", "age": 30, "is_active": true } # 잘 저장됐는 지 확인하기 GET /users/_search # 이미 존재하는 id로 데이터 저장하면 어떻게 되는 지 확인하기 POST /users/_doc/2 { "name": "jason2", "age": 30, "is_active": true } # 어떻게 됐는 지 확인하기 GET /users/_search
       
       
 

✅ 도큐먼트 조회

  1. (특정 인덱스의) 모든 도큐먼트 조회
    1. # GET /{인덱스명}/_search GET /users/_search
       
  1. id로 특정 도큐먼트 조회
    1. # 특정 도큐먼트 조회 # GET /{index}/_doc/{id} GET /users/_doc/1 GET /users/_doc/2
 
👨🏻‍🏫
이 외에도 다양한 조건을 활용해 데이터를 조회하는 방법이 있다. 하지만 이 부분은 나중에 자세히 다룰 예정이다. 우선 기본적인 기능을 빠르게 배워 실전에서 빨리 써먹어보자. 그래야 전체 흐름을 빨리 파악할 수 있다.
 

✅ 도큐먼트 수정

  1. 도큐먼트를 통째로 덮어씌우기
    1. # 기존 도큐먼트 확인 GET /users/_doc/1 # 특정 도큐먼트 수정 # 이 API는 데이터 저장 시에도 사용하는 API이다. (바로 위에서 언급했었음) # PUT /{인덱스명}/_doc/{id} PUT /users/_doc/1 { "name": "new" } # 수정됐는 지 확인하기 GET /users/_doc/1
       
  1. 일부 필드만 수정
    1. # 기존 도큐먼트 확인 GET /users/_doc/2 # 특정 도큐먼트 수정 # POST /{인덱스명}/_update/{id} POST /users/_update/2 { "doc": { "age": 10, "is_active": false } } # 수정됐는 지 확인하기 GET /users/_doc/2
       

✅ 도큐먼트 삭제하기

# 기존 도큐먼트 확인 GET /users/_doc/2 # id로 도큐먼트 삭제하기 # DELETE /{인덱스명}/_doc/{id} DELETE /users/_doc/2 # 삭제됐는 지 확인하기 GET /users/_doc/2
 
 
👨🏻‍🏫
Elasticsearch는 데이터베이스의 일종이라고 설명했었다. 데이터베이스의 핵심 기능인 CRUD(저장, 조회, 수정, 삭제)를 알아봤다. 이 기능만 가지고 실제 프로젝트에서 써먹어보자.
 
author
JSCODE 박재성
category
Elasticsearch
createdAt
Dec 6, 2025
series
실전에서 바로 써먹는 Elasticsearch 입문 (검색 최적화편)
slug
type
series-footer
updatedAt
Dec 6, 2025 05:12 AM
📎
이 글은 실전에서 바로 써먹는 Elasticsearch 입문 (검색 최적화편) 강의의 수업 자료 중 일부입니다.