# 데이터 탐색기

## 개요

Panther Console의 Data Explorer에서는 정규화된 Panther 데이터를 확인하고 SQL 쿼리(자동 완성 포함)를 실행할 수 있습니다.

Data Explorer에서는 다음을 할 수 있습니다:

* 수집된 로그 데이터, 룰 일치 항목을 탐색하고 모든 데이터에서 표준 필드를 검색
* AI를 사용해 자연어 설명으로부터 SQL 쿼리를 생성
* [검색을 저장하고, 필요하면 예약](#how-to-manage-saved-searches-in-data-explorer)
  * [예약 검색](/ko/search/scheduled-searches.md) 룰 엔진을 통해 실행할 수 있습니다
* 생성 [템플릿 검색 및 매크로](/ko/search/scheduled-searches/templated-searches.md)
* 공유 가능한 링크를 통해 팀과 결과를 공유하거나, CSV로 결과를 다운로드
* JSON의 전체 행을 선택하여 룰 엔진에서 단위 테스트로 사용
* SQL 없이 테이블 데이터를 미리 보고, 결과를 필터링하고, 열을 요약
* 다음을 통해 Data Explorer에 대한 액세스를 제한 [역할 기반 액세스 제어](/ko/system-configuration/rbac.md) (RBAC)

{% hint style="warning" %}
다음을 포함하는 Data Explorer 결과 `bigint` 32비트 정밀도를 초과하는 데이터는 브라우저의 JSON 렌더링 제한으로 인해 반올림되어 표시됩니다. 이러한 값이 정밀도 손실 없이 표시되도록 하려면 SQL 명령에서 문자열로 형변환하세요. 데이터 레이크에 저장된 실제 데이터에는 영향을 주지 않습니다.
{% endhint %}

## Data Explorer의 쿼리 구문

Data Explorer에서 실행되는 쿼리는 Snowflake의 [SQL Command Reference](https://docs.snowflake.com/en/sql-reference-commands) 문서에 설명된 Snowflake SQL 구문을 사용해야 합니다.

다음도 배울 수 있습니다:

* Data Explorer에서 검색할 때의 모범 사례, [Data Explorer에서 효과적으로 검색하기](#searching-effectively-in-data-explorer)
* 다음 방법 [Data Explorer에서 중첩 필드 참조](#referencing-nested-fields-in-data-explorer)
* 사용 방법 [Data Explorer 매크로](#how-to-use-data-explorer-macros)

### Data Explorer에서 중첩 필드 참조

JSON 객체를 탐색할 때 키 이름이 다음 규칙을 따르지 않으면 [Snowflake SQL 식별자 규칙](https://docs.snowflake.com/en/sql-reference/identifiers-syntax)—예를 들어 점이나 공백이 포함된 경우— 값을 큰따옴표로 감싸세요.

예를 들어, 다음 필드에 접근하는 쿼리를 실행하려면 `context.ip_address` 에서 [IPInfo Privacy Enrichment Provider](/ko/enrichment/ipinfo.md)를 다음과 같이 작성합니다 `p_enrichment:ipinfo_privacy:"context.ip_address"`.

Snowflake의 [Querying Semi-structured Data](https://docs.snowflake.com/en/user-guide/querying-semistructured) 문서에 설명된 Snowflake SQL 구문을 사용해야 합니다.

### Data Explorer에서 효과적으로 검색하기

결과를 가능한 한 빨리 반환하려면 다음 모범 사례를 따르는 것이 좋습니다:

* **다음을 사용 `LIMIT` 절**
  * 다음을 사용 `LIMIT` 절을 사용해 쿼리에서 반환할 레코드 수를 지정하세요. 쿼리 결과 수를 제한하면 더 빨리 결과를 반환할 수 있습니다. Panther는 기본적으로 결과 크기를 100MB로 제한합니다.
* **시간 범위 필터 사용**
  * Snowflake는 S3의 파일을 [마이크로파티션](https://docs.snowflake.com/en/user-guide/tables-clustering-micropartitions.html). 시간 범위(예: `p_event_time` 또는 `p_occurs_since()`)으로 필터링하면 Snowflake는 특정 파티션만 액세스하면 되므로 결과를 더 빨리 반환합니다.
  * 매크로에 대한 자세한 내용은 아래 섹션을 참조하세요:[ Data Explorer 매크로 사용 방법](#how-to-use-data-explorer-macros).
* **p\_any 필드 사용**
  * 로그 수집 중 Panther는 일반적인 보안 지표를 `p_any` 필드로 추출합니다. 해당 `p_any` 필드는 최적화된 열에 저장됩니다. 이 필드는 모든 데이터 소스에서 속성 이름을 표준화하여 빠른 데이터 상관관계를 가능하게 합니다.
  * 자세히 알아보기: [표준 필드](/ko/search/panther-fields.md).
* **특정 필드 쿼리**
  * 사용 `SELECT * FROM ...` 는 모든 열을 가져오므로 쿼리가 느려질 수 있습니다. 가능하면 조사에 필요한 필드만 쿼리하세요. 예: `SELECT user_name, event_name FROM ...`.
* **요약**
  * 요약은 전체 레코드를 쿼리하는 것보다 더 빠르게 실행됩니다. 이는 특히 긴 기간의 로그를 조사할 때, 또는 조사 중인 기간에 데이터가 얼마나 존재하는지 확실하지 않을 때 유용합니다.
  * 전체 데이터 세트를 쿼리하는 대신 다음을 사용할 수 있습니다 `count(*)` 및 `group by` 를 시간 범위에 적용하면 더 빨리 실행되며 이후 쿼리할 더 좁은 기간을 결정하는 데 도움이 됩니다.
  * 예를 들어 하루를 되돌아보고 `GROUP BY hour`를 사용하면 데이터에서 조사해야 할 특정 시간을 파악할 수 있습니다. 그런 다음 해당 시간에 대해 쿼리를 실행하여 결과를 더 좁힐 수 있습니다.

위의 모범 사례를 따랐는데도 쿼리가 여전히 느리게 실행된다면 다음 단계를 권장합니다:

* 행 수를 계산하여 쿼리 중인 데이터 양을 확인하세요.
  * 이를 통해 데이터 양이 많은지, 그리고 시간이 더 걸리는 것이 예상되는지 판단하는 데 도움이 됩니다.
* 쿼리하는 시간 범위를 줄이세요.
* 추가 도움이 필요하면 Panther Support 팀에 문의하세요.

## **Data Explorer 사용 방법**

### **Data Explorer 액세스**

* Panther Console의 왼쪽 탐색 바에서 **Investigate > Data Explorer**.

<figure><img src="/files/b3eac15b6d981467126bf36b439de253ac97d289" alt="The Data Explorer page has a column on the left labeled Tables. In the middle of the page, there is a text editor labeled New Query. The bottom of the page has tabs labeled Results and Summarize."><figcaption></figcaption></figure>

### 표 데이터 미리 보기

SQL을 작성하지 않고 예시 테이블 데이터를 미리 볼 수 있습니다. 해당 로그 소스의 샘플 SQL 쿼리를 생성하려면 테이블 유형 옆의 눈 아이콘을 클릭하세요:

<figure><img src="/files/8f2ee605083a2f546a11615df8bd5c1501350ce9" alt="In Data Explorer, under the Tables column, each log source has an eye icon next to it. The image shows a red circle around the eye icons."><figcaption></figcaption></figure>

### Data Explorer 결과 필터링

SQL을 작성하지 않고 Data Explorer의 결과 세트에서 열을 필터링할 수 있습니다.

결과 테이블의 오른쪽 상단에서 **Filter Columns** 를 클릭하여 결과에 표시할 열을 선택하세요:

<figure><img src="/files/6e497a00a3b9fbd784b2600721742eacd8439891" alt="The Results tab of the Data Explorer shows there are 3202 Results. The Query Time was 528 ms, and the Data Scanned was 1.89MB. There is a select dropdown that has &#x22;Filter Columns (3)&#x22; selected, and a &#x22;Download CSV&#x22; button."><figcaption></figcaption></figure>

참고: 이 메커니즘을 통해 적용된 필터는 쿼리의 SQL select 문에는 적용되지 않습니다.

### 열 데이터 요약

SQL을 작성하지 않고 Data Explorer의 결과 세트에서 열의 요약(빈도 수)을 생성할 수 있습니다.

요약을 생성할 열에서 아래 화살표를 클릭한 다음 **요약** 을 클릭하여 별도의 탭에 요약 결과를 표시하세요.

<figure><img src="/files/65f250db5728d94f5403b902a11c5831a4bf3b2e" alt="The Results tab of the Data Explorer shows there are 3202 Results. The Query Time was 528 ms, and the Data Scanned was 1.89MB. There is a select dropdown that has &#x22;Filter Columns (3)&#x22; selected, and a &#x22;Download CSV&#x22; button. The first result of the query is shown in table format. The following fields are visible: p_timeline, type, timestamp, elb, clientIp, clientPort, targetIp, targetPort, requestProcessingTime, and targetProcessingTime."><figcaption></figcaption></figure>

쿼리가 실행된 후에도 첫 번째 요약은 **요약** 탭으로 전환하고 드롭다운에서 열을 선택하여 생성할 수 있습니다.

<figure><img src="/files/8d96652f61b7cdee948fd26ebed299a43dd7f0bb" alt="In the Summarize tab, the type-ahead dropdown allows selecting a column to summarize"><figcaption></figcaption></figure>

선택한 열의 요약 결과는 Summary 탭에 표시되며, 결과를 가장 높은 카운트 또는 가장 낮은 카운트 순으로 정렬할 수 있습니다(기본값은 가장 높은 카운트 순).

<figure><img src="/files/9eae72f8a467ee6e959333b2ec888dbd6e056980" alt="row_count represents the frequency of each unique clientIp in the result set"><figcaption></figcaption></figure>

다음 외에도 `row_count` 값, 요약에는 또한 `first_seen` 및 `last_seen` 값이 결과 데이터에 다음이 포함된 경우 표시됩니다 `p_event_time` [표준 필드](/ko/search/panther-fields.md).

## AI 기반 SQL 쿼리 생성

{% hint style="info" %}
이 기능을 사용하려면 **Enable Panther AI** 설정을 활성화해야 합니다. 또한 사용자 역할에 다음 권한이 있어야 합니다 **Run Panther AI** .
{% endhint %}

Panther AI는 자연어를 사용하여 Data Explorer에서 SQL 쿼리를 생성하는 데 도움을 줄 수 있습니다. Panther AI는 쿼리할 권한이 있는 로그 유형과 데이터에만 접근하며 읽기 전용 도구만 사용합니다. 쿼리를 실행하거나 데이터를 수정할 수 없습니다.

AI 기반 SQL 쿼리 생성을 사용하려면:

1. Panther Console의 왼쪽 탐색 바에서 **Investigate > Data Explorer**.
2. Panther AI 프롬프트에 쿼리하고 싶은 내용을 자연어로 입력하세요. 예:
   * "지난 24시간 동안 실패한 로그인 시도를 보여줘"
   * "특정 사용자의 CloudTrail 이벤트를 모두 찾아줘"
   * "소스 IP 주소별 이벤트 수를 구해줘"
3. 설정 아이콘을 클릭하여 선호하는 추론 수준을 선택하세요:
   * **기본**: 빠르고 간결한 응답
   * **표준**: 균형 잡힌 분석(권장)
   * **고급**: 포괄적인 설명이 포함된 상세 분석
4. 다음 아이콘을 클릭하거나 **Generate query** 아이콘을 클릭하거나 Enter 키를 눌러 SQL 쿼리를 생성하세요.
5. AI가 요청에 따라 SQL 쿼리를 생성합니다. 쿼리를 검토한 다음 **Run query** 를 클릭하여 실행하세요.

<figure><img src="/files/39a657ebaa77afe87feb704249a49c8421e4367e" alt=""><figcaption></figcaption></figure>

#### 효과적인 프롬프트를 위한 팁

* **시간 범위를 구체적으로 지정하세요**: "지난 1시간의 이벤트" 또는 "2024-01-01과 2024-01-02 사이의 데이터"
* **특정 필드나 열을 언급하세요** "source\_ip로 group by" 또는 "event\_name에 'login'이 포함된 경우"
* **테이블을 지정하세요** 특정 로그 유형을 쿼리하려는 경우: "CloudTrail 이벤트 중..."
* **요약 또는 집계를 요청하세요**: "사용자별 count", "상위 10개 source IP", "시간별 분해"

## Data Explorer 매크로 사용 방법

지원되는 백엔드 데이터베이스의 모든 테이블은 시간 필터를 사용한 쿼리 성능 향상을 위해 이벤트 시간 기준으로 분할되어 있습니다.

효율성과 사용 편의성을 위해 Panther는 데이터베이스로 전송될 때 전체 표현식으로 확장되는 매크로를 제공합니다:

* [현재 시간: `p_current_timestamp`](#current-time-p_current_timestamp)
* [시간 범위 필터: `p_occurs_between`](#time-range-filter-p_occurs_between)
* [현재 시점으로부터의 시간 오프셋: `p_occurs_since`](#time-offset-from-present-p_occurs_since)
* [특정 시간 주변 필터: `p_occurs_around`](#filter-around-a-certain-time-p_occurs_around)

{% hint style="info" %}
이 매크로는 템플릿 매크로와 다릅니다. 템플릿 매크로에 대해 자세히 알아보려면 다음을 참조하세요 [템플릿 검색](/ko/search/scheduled-searches/templated-searches.md).
{% endhint %}

### 매크로 형식 <a href="#time-offset-format" id="time-offset-format"></a>

#### 시간 지속 형식 <a href="#time-offset-format" id="time-offset-format"></a>

일부 매크로는 시간 지속을 매개변수로 사용합니다. 이 지속 형식은 양의 정수 뒤에 선택적 접미사가 붙어 시간 단위를 나타냅니다. 접미사가 없으면 숫자는 초로 해석됩니다.

지원되는 접미사는 아래 목록에 있습니다:

* `s, sec, second, seconds` — 매크로가 지정된 초를 더합니다
* `m, min, minute, minutes` — 매크로가 지정된 분을 오프셋에 더합니다
* `h, hr, hrs, hour, hours` — 매크로가 지정된 시간을 오프셋에 더합니다
* `d, day, days` — 매크로가 지정된 일을 오프셋에 더합니다
* `w, wk, week, weeks` — 매크로가 지정된 주 수를 오프셋에 더합니다
* 접미사가 감지되지 않으면 기본값은 초입니다

예:

* `'6 d'` - 6일
* `'2 weeks'` - 2주
* `900` - 900초
* `'96 hrs'` - 96시간

#### 타임스탬프 형식

시간 표현식이 팀이 사용하는 데이터베이스 백엔드에서 파싱될 수 있는지 확인하세요. 기본 안전 시간 형식은 아마도 다음과 비슷해야 하며 `2021-01-02 15:04:05.000` UTC 시간대로 간주됩니다.

### Data Explorer 매크로

#### 현재 시간: `p_current_timestamp`

`p_current_timestamp()`

이 매크로는 다음으로 확장됩니다 `current_timestamp` Data Explorer에서는 이 값으로 확장되지만, [`p_occurs_since`](#time-offset-from-present-p_occurs_since)와 유사하게 예약 쿼리에서 실행될 때는 쿼리의 예약된 시간으로 확장됩니다(실제로 쿼리가 실행되는 시점과 무관).

#### 시간 범위 필터: `p_occurs_between`

`p_occurs_between(startTime, endTime, [, tableAlias [, column]])`

* `startTime` - 다음 형식의 시간 [타임스탬프 형식](#timestamp-format), 검색 창의 시작을 나타냄
* `endTime` - 다음 형식의 시간 [타임스탬프 형식](#timestamp-format), 검색 창의 끝을 나타냄
* `tableAlias` - 제공된 경우 테이블 별칭으로 사용될 선택적 식별자
* `column` - 제공된 경우 열로 사용될 선택적 식별자
  * 없으면 기본 열은 `p_event_time`.
  * 다른 열을 지정하면(예: `p_parsed_time`) `column` 를 사용하면, 다음에 대한 제한이 없을 경우 전체 테이블을 검색하므로 쿼리 시간이 훨씬 길어질 수 있습니다 `p_event_time`.

매크로 `p_occurs_between()` 는 다음 형식의 시작 시간과 종료 시간을 사용합니다 [타임스탬프 형식](#timestamp-format) 그리고 올바른 파티션을 사용하여 시간 범위 내 이벤트만 결과 세트로 필터링합니다(I/O를 최소화하고 쿼리를 빠르게 함).

올바르게 사용하려면 이 매크로는 다음과 같은 필터 안에 있어야 합니다 `WHERE` 절.

다음 Snowflake 명령에는 매크로가 포함되어 있습니다:

```sql
select p_db_name, count(*) as freq from panther_views.public.all_databases
where p_occurs_between(current_date - 1, current_timestamp)
group by p_db_name
limit 1000
```

매크로는 쿼리가 데이터베이스로 전송되기 전에 자동으로 확장됩니다. 확장 방식은 데이터베이스마다 다릅니다. Snowflake에서는 이 확장이 매우 간단합니다:

```sql
select p_db_name, count(*) as freq from panther_views.public.all_databases
where p_event_time between convert_timezone('UTC',current_date - 1)::timestamp_ntz
    and convert_timezone('UTC',current_timestamp)::timestamp_ntz
group by p_db_name
limit 1000
```

이 매크로는 선택적 테이블 별칭도 사용합니다. 이는 다음과 같은 여러 테이블을 참조할 때 유용할 수 있습니다 `JOIN`:

```sql
select aws.awsRegion, ata.digestEndTime
from panther_logs.public.aws_cloudtrail as aws
join panther_logs.public.aws_cloudtraildigest as ata ON aws.awsRegion = ata.awsAccountId
where p_occurs_between('2023-01-01', '2023-06-30', aws)
limit 10
```

#### 현재 시점으로부터의 시간 오프셋: `p_occurs_since`

`p_occurs_since(offsetFromPresent [, tableAlias[, column]])`

* `offsetFromPresent` - 다음 형식의 표현식 [시간 지속 형식](#time-offset-format), 현재 기준으로 해석되며, 예: `'1 hour'`
* `tableAlias` - 제공된 경우 테이블 별칭으로 사용될 선택적 식별자
* `column` - 제공된 경우 열로 사용될 선택적 식별자
  * 없으면 기본 열은 `p_event_time`.
  * 다른 열을 지정하면(예: `p_parsed_time`) `column` 를 사용하면, 다음에 대한 제한이 없을 경우 전체 테이블을 검색하므로 쿼리 시간이 훨씬 길어질 수 있습니다 `p_event_time`.

매크로 `p_occurs_since()` 은 다음으로 지정된 오프셋 매개변수를 사용합니다 [시간 지속 형식](#time-offset-format) 그리고 올바른 파티션 또는 클러스터 키를 사용하여 현재 시간과 지정된 오프셋 사이의 이벤트만 결과 세트로 필터링합니다(I/O를 최소화하고 쿼리를 빠르게 함).

이 매크로는 여러 테이블을 참조할 때 유용할 수 있는 선택적 테이블 별칭도 사용합니다 `JOIN`.

올바르게 사용하려면 이 매크로는 다음과 같은 필터 안에 있어야 합니다 `WHERE` 절.

#### 예:

```sql
p_occurs_since('6 d')
p_occurs_since('2 weeks')
p_occurs_since(900) // 초로 가정
p_occurs_since('96 hrs')
```

{% hint style="info" %}
만약 `p_occurs_since` 가 다음에서 사용되면 [예약 검색](/ko/search/scheduled-searches.md), 현재 시간을 기준으로 사용하는 대신 예약 실행 시간이 사용됩니다. 예를 들어 쿼리가 매 시간 시작에 실행되도록 예약된 경우 `p_occurs_since('1 hour')` 매크로는 각 시간 시작 시점부터 1시간 범위로 확장됩니다(실제로 쿼리가 실행되는 시점과 무관). 자세한 내용은 다음에서 확인하세요 [사용 `p_occurs_since` 룩백 창 정의](/ko/search/scheduled-searches.md#using-p_occurs_since-to-define-a-lookback-window).
{% endhint %}

다음은 테이블 별칭 매개변수가 있는 매크로 예시입니다. CloudTrail 로그를 살펴 S3 버킷이 생성된 후 1시간 이내에 삭제되었는지 확인하는데, 이는 잠재적으로 의심스러운 행동입니다. 이 정보를 얻기 위해 `aws_cloudtrail` 테이블에서 `panther_logs`를 사용해 self-join을 수행하고, self-join의 두 요소 각각에 대해 지난 24시간으로 검색 범위를 제한하기 위해 매크로 확장을 사용합니다(별칭 `ct1` 및 `ct2` 는 아래와 같음):

```sql
select 
ct1.p_event_time createTime, ct2.p_event_time deleteTime,
timediff('s',createTime, deleteTime) timeExtant,
ct1.requestparameters:"bucketName"::varchar createdBucket,
ct1.useridentity:"arn"::varchar createArn, deleteArn,
ct1.useragent createUserAgent, deleteUserAgent
from panther_logs.public.aws_cloudtrail ct1
join (
select p_event_time, requestparameters:"bucketName"::varchar deletedBucket, errorcode,
  eventname deleteEvent, useridentity:"arn"::varchar deleteArn, useragent deleteUserAgent  from panther_logs.public.aws_cloudtrail) ct2
on (ct1.requestparameters:"bucketName"::varchar = ct2.DeletedBucket
    and ct2.p_event_time > ct1.p_event_Time
    and timediff('s',ct1.p_event_time, ct2.p_event_time) < 3600)
where ct2.deleteEvent = 'DeleteBucket'
and ct1.eventName = 'CreateBucket'
and ct1.errorCode is null and ct2.errorcode is null
and p_occurs_since('1 day',ct2)  -- ct2에 적용
and p_occurs_since('24 hours',ct1)  -- ct1에 적용
order by createdBucket, createTime;
```

다음에 대한 두 개의 별도 호출이 있습니다 `p_occurs_since` 각각 다른 테이블에 적용되며, 두 번째 매개변수로 사용된 테이블 별칭에서 이를 알 수 있습니다. 이는 다음 Snowflake 쿼리로 확장됩니다:

```sql
select 
ct1.p_event_time createTime, ct2.p_event_time deleteTime,
timediff('s',createTime, deleteTime) timeExtant,
ct1.requestparameters:"bucketName"::varchar createdBucket,
ct1.useridentity:"arn"::varchar createArn, deleteArn,
ct1.useragent createUserAgent, deleteUserAgent
from panther_logs.public.aws_cloudtrail ct1
join (
select p_event_time, requestparameters:"bucketName"::varchar deletedBucket, errorcode,
  eventname deleteEvent, useridentity:"arn"::varchar deleteArn, useragent deleteUserAgent  from panther_logs.public.aws_cloudtrail) ct2
on (ct1.requestparameters:"bucketName"::varchar = ct2.deletedBucket
    and ct2.p_event_time > ct1.p_event_Time
    and timediff('s',ct1.p_event_time, ct2.p_event_time) < 3600)
where ct2.deleteEvent = 'DeleteBucket'
and ct1.eventName = 'CreateBucket'
and ct1.errorCode is null and ct2.errorcode is null
and ct2.p_event_time >= current_timestamp - interval '86400 second'
and ct1.p_event_time >= current_timestamp - interval '86400 second'
order by createdBucket, createTime;
```

#### 특정 시간 주변 필터: `p_occurs_around`

`p_occurs_around(timestamp, timeOffset [, tableAlias[, column]])`

* `timestamp` - 다음 형식의 시간 [타임스탬프 형식](#timestamp-format), 검색할 기준 시간이 되는
* `timeOffset` - 다음 형식의 표현식 [시간 지속 형식](#time-offset-format), 기준 시간 주변에서 검색할 시간의 양을 나타냄 `timestamp`, 예: `'1 hour'`
* `tableAlias` - 제공된 경우 열 별칭으로 사용될 선택적 식별자
* `column` - 제공된 경우 열로 사용될 선택적 식별자
  * 없으면 기본 열은 `p_event_time`.
  * 다른 열을 지정하면(예: `p_parsed_time`) `column` 를 사용하면, 다음에 대한 제한이 없을 경우 전체 테이블을 검색하므로 쿼리 시간이 훨씬 길어질 수 있습니다 `p_event_time`.

**참고**: 사용 중인 인스턴스의 데이터베이스 백엔드에서 시간 표현식을 파싱할 수 있는지 확인하세요. 자세한 내용은 다음을 참조하세요 [타임스탬프 형식](#timestamp-format).

해당 `p_occurs_around()` 매크로를 사용하면 주어진 시간 주변에 발생한 이벤트를 필터링할 수 있습니다. 이 매크로는 다음 형식의 타임스탬프를 사용합니다 [타임스탬프 형식](#timestamp-format) 검색할 기준 시간을 나타내며, 다음 형식의 오프셋을 사용합니다 [시간 지속 형식](#time-offset-format) 검색할 간격을 지정합니다. 검색 범위는 다음과 같습니다 `timestamp - timeOffset` 부터 `timestamp + timeOffset`.

예를 들어, 매크로 `p_occurs_around('2022-01-01 10:00:00.000', '10 m')` 는 2022년 1월 1일 UTC 오전 9:50부터 오전 10:10 사이에 발생한 이벤트를 필터링합니다.

이 매크로는 여러 테이블을 참조할 때 유용할 수 있는 선택적 테이블 별칭도 사용합니다 `JOIN`.

올바르게 사용하려면 이 매크로는 다음과 같은 필터 안에 있어야 합니다 `WHERE` SQL 문장의 절.

#### 예:

```sql
p_occurs_around('2022-01-01 10:00:00.000', '6 d')
p_occurs_around('2022-01-01 10:00:00.000', '2 weeks')
p_occurs_around('2022-01-01 10:00:00.000', 900) // 초로 가정
p_occurs_around('2022-01-01 10:00:00.000', '96 hrs')
```

## Data Explorer에서 저장된 검색을 관리하는 방법

Data Explorer에서 자주 실행하는 검색을 저장해 두면 같은 내용을 계속 다시 작성할 필요가 없습니다.

{% hint style="info" %}
Saved Search를 삭제하는 방법은 다음에 설명되어 있습니다 [저장 및 예약 쿼리](/ko/search/scheduled-searches.md#how-to-delete-or-download-a-saved-search).
{% endhint %}

### Data Explorer에서 저장 또는 예약 검색 만들기

아래는 Data Explorer에서 작성한 검색을 저장하는 방법에 대한 지침입니다. 또한 다음도 할 수 있습니다 [Search에서 저장된 검색 만들기](/ko/search/search-tool.md#creating-a-saved-search).

1. Panther Console의 왼쪽 탐색 바에서 **Investigate** > **Data Explorer**.
2. SQL 편집기에서 SQL을 사용해 검색을 작성하세요.
   * 다음에 대한 시스템 전체 설정을 활성화한 경우 [LIMIT 절 필요](#use-limits-in-scheduled-queries)를 확인하고 쿼리에 LIMIT가 포함되어 있는지 확인하세요.\
     ![The image shows an example query written in the Scheduled Query text editor in the Panther Console.](/files/ba80cd02c92c0da8f3e1cba0770a0ef26bba0341)
   * SQL 표현식에 변수를 포함하여 템플릿 검색을 만들 수 있습니다. 자세한 내용은 다음에서 확인하세요 [템플릿 검색](/ko/search/scheduled-searches/templated-searches.md).
3. SQL 편집기 아래에서 다음을 클릭하세요 **Save as**.
4. 다음에서 **Save Search** 모달이 나타나면 양식을 채우세요:
   * **Search Name**: 설명적인 이름을 추가하세요.
   * **Tags**: 유사한 검색을 함께 그룹화하는 데 도움이 되도록 태그를 추가하세요.
   * **Description**: 검색 목적을 설명하세요.
   * **Default Database**: 쿼리를 실행할 데이터베이스를 선택하세요.
   * **예약 검색 만들기**: 이 저장된 검색을 예약된 일정으로 실행하려면(예약 검색이 되도록) 토글을 **ON**으로 전환하세요. 이 토글을 **ON**으로 전환하면 아래 옵션이 표시됩니다:
     * **활성 실행 중인가요?**: 이 예약 검색을 선택한 일정에 따라 실행하도록 하려면 토글을 **ON**.
     * 다음 중 하나를 클릭하여 일정을 구성하세요:
       * **Period** (쿼리를 고정된 시간 간격으로 실행하려면 선택):
         * **Period(days)** 및 **Period(min)**: SQL 쿼리를 다시 실행해야 하는 일수 및/또는 분 수를 입력하세요. 예: 0일 30분으로 설정하면 쿼리가 매일 30분마다 실행됩니다.
         * **Timeout(min)**: 허용 가능한 최대값 10분으로 제한된 시간 초과 기간을 분 단위로 입력하세요. 쿼리가 허용 시간 내에 완료되지 않으면 Panther는 자동 취소하기 전에 3번 재시도합니다.
       * **Cron Expression** (쿼리를 특정 날짜에 반복 실행하려면 선택하고, cron 표현식을 만드는 방법에 대해 자세히 알아보려면 다음을 참조하세요 [예약 검색 crontab 사용 방법](/ko/search/scheduled-searches.md#how-to-use-the-scheduled-search-crontab)):
         * **Minutes** 및 **Hours**: 쿼리가 실행될 시간을 입력하세요.
         * **Day** 및 **Month** (month의 day): 이 쿼리를 특정 일자와 월에 실행하려면 해당 일자와 월을 입력하세요.
         * **Day** (day of week): 이 쿼리를 특정 요일에 실행하려면 해당 요일을 입력하세요.
         * **Timeout**: 허용 가능한 최대값 10분으로 제한된 시간 초과 기간을 분 단위로 입력하세요. 쿼리가 허용 시간 내에 완료되지 않으면 Panther는 자동 취소하기 전에 3번 재시도합니다.
     * **예약 검색 결과 이메일 발송**: 검색 결과를 이메일로 보내고 싶다면 이 토글을 **ON**로 전환하세요. 자세한 내용은 다음에서 확인하세요 [예약 검색을 이메일 보고서로 생성하도록 구성하는 방법](/ko/search/scheduled-searches.md#how-to-configure-a-scheduled-search-to-generate-an-email-report).\
       ![The image shows the Search creation screen. There are fields for Search Name, Tags, Description, and Default Database. Next to "Is this a Scheduled Search?" the toggle is set to "on." Next to "Is it active?" the toggle is set to "On." The interval option "Period" is selected.](/files/141d4b3d2ee4adbb908e28a9337e7ba138b8741c)
5. 다음을 클릭하세요 **Save Search**.

{% hint style="info" %}
예약 검색을 만들었다면(토글하여 **예약 검색 만들기** 부터 **ON)**&#xC774;제 다음을 할 수 있습니다 [예약 룰을 만드는 지침을 따르세요](/ko/detections/rules.md#how-to-write-rules-and-scheduled-rules) 검색 결과로 반환된 데이터를 디택션을 통해 전달하고 싶다면.
{% endhint %}

### Data Explorer에서 저장 또는 예약 검색 업데이트

1. Panther Console의 왼쪽 탐색 바에서 **Investigate** > **Data Explorer**.
2. 오른쪽 상단에서 다음을 클릭하세요 **Open Saved Search**.
   * 다음의 **Open a Search** 모달이 나타납니다.
3. 모달에서 업데이트할 Saved Search를 선택한 다음 **Open Search**.
   * 을 클릭하세요.
4. Saved Search가 Data Explorer SQL 편집기에 표시됩니다.
5. 편집기 아래에서 다음을 클릭하세요 **Update**.\
   ![The bottom of the SQL editor in Data Explorer is shown. Below the editor are two buttons: Run Search and Update. The Update button is circled.](/files/b9c86ee6fe5677877caf7ed4524d5cad52723b08)
   * 다음의 **Update Search** 모달이 나타납니다.
6. 다음을 포함하여 Saved Search의 메타데이터를 원하는 대로 변경하세요. **Search Name**, **Tags**, **Description**, **Default Database**와 **Create a scheduled search** (및 관련 필드).
7. 다음을 클릭하세요 **Update Search** 를 눌러 변경 사항을 저장하세요.


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.panther.com/ko/search/data-explorer.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
