기타 함수
아래 함수 관련 문서는 system.functions 시스템 테이블에서 자동 생성되었습니다.
FQDN
도입 버전: v20.1.0
ClickHouse 서버의 정규화된 도메인 이름(fully qualified domain name, FQDN)을 반환합니다.
구문
별칭: fullHostName
인수
- 없음.
반환값
ClickHouse 서버의 정규화된 도메인 이름(fully qualified domain name, FQDN)을 반환합니다. String
예시
사용 예시
MACNumToString
도입 버전: v1.1.0
UInt64 숫자를 빅 엔디언(Big Endian) 형식의 MAC 주소로 해석합니다.
해당 숫자에 대응하는 MAC 주소를 문자열로 반환하며, 형식은 AA:BB:CC:DD:EE:FF (콜론으로 구분된 16진수 숫자)입니다.
구문
인수
num— UInt64 값.UInt64
반환값
AA:BB:CC:DD:EE:FF 형식의 MAC 주소를 반환합니다. String
예시
사용 예시
MACStringToNum
도입 버전: v1.1.0
MACNumToString의 역함수입니다. MAC 주소의 형식이 유효하지 않으면 0을 반환합니다.
구문
인수
s— MAC 주소 문자열.String
반환 값
UInt64 값을 반환합니다. UInt64
예시
사용 예시
MACStringToOUI
도입 버전: v1.1.0
AA:BB:CC:DD:EE:FF 형식(콜론으로 구분된 16진수 숫자)의 MAC 주소가 주어지면, 앞의 세 옥텟을 UInt64 값으로 반환합니다. MAC 주소 형식이 잘못된 경우 0을 반환합니다.
구문
인수
s— MAC 주소 문자열.String
반환 값
앞의 세 옥텟을 UInt64 숫자 값으로 반환합니다. UInt64
예시
사용 예시
authenticatedUser
도입 버전: v25.11.0
세션 사용자가 EXECUTE AS 명령으로 변경된 경우, 이 FUNCTION은 인증 및 세션 생성에 사용된 원래 사용자의 이름을 반환합니다.
별칭(Alias): authUser()
구문
별칭: authUser
인수
- 없음.
반환값
인증된 사용자 이름입니다. String
예시
사용 예시
bar
도입 버전: v1.1.0
막대 차트를 생성합니다. (x - min)에 비례하는 너비를 가지며, x = max일 때 width 개의 문자 길이가 되도록 띠(band)를 그립니다. 이 띠는 문자 하나를 8등분한 단위까지의 정밀도로 그려집니다.
구문
인수
x— 표시할 크기.(U)Int*또는Float*또는Decimalmin— 최소값.(U)Int*또는Float*또는Decimalmax— 최대값.(U)Int*또는Float*또는Decimalwidth— 선택 사항입니다. 막대의 문자 단위 너비입니다. 기본값은80입니다.const (U)Int*또는const Float*또는const Decimal
반환 값
유니코드 아트 형태의 막대 문자열을 반환합니다. String
예시
사용 예시
blockNumber
도입 버전: v1.1.0
행이 포함된 block의 단조 증가하는 시퀀스 번호를 반환합니다. 반환되는 block 번호는 best-effort 방식으로 업데이트되므로 완전히 정확하지 않을 수 있습니다.
구문
인수
- 없음.
반환값
행이 위치한 데이터 블록의 시퀀스 번호입니다. UInt64
예제
기본 사용
blockSerializedSize
도입 버전: v20.3.0
디스크에 저장된 값들의 블록이 비압축 상태일 때의 크기를 바이트 단위로 반환합니다.
구문
인수
x1[, x2, ...]— 압축되지 않은 블록의 크기를 계산할 임의 개수의 값.Any
반환 값
압축 없이 값들의 블록을 디스크에 기록할 때 기록되는 바이트 수를 반환합니다. UInt64
예시
사용 예시
blockSize
도입된 버전: v1.1.0
ClickHouse에서는 쿼리가 블록 (청크) 단위로 처리됩니다. 이 함수는 호출된 블록의 크기(행 수)를 반환합니다.
구문
인수
- 없습니다.
반환 값
현재 블록에 있는 행의 개수를 반환합니다. UInt64
예시
사용 예시
buildId
도입 버전: v20.5.0
실행 중인 ClickHouse 서버 바이너리에 대해 컴파일러가 생성한 빌드 ID를 반환합니다. 분산 테이블 컨텍스트에서 실행되는 경우 이 함수는 각 세그먼트에 해당하는 값을 갖는 일반 컬럼을 생성합니다. 그 외의 경우에는 상수 값을 생성합니다.
구문
인수(Arguments)
- 없음.
반환값(Returned value)
빌드 ID를 반환합니다. String
예시(Examples)
사용 예시(Usage example)
byteSize
도입 버전: v21.1.0
인수들의 메모리 상 비압축 바이트 크기를 추정한 값을 반환합니다.
String 인수의 경우 문자열 길이에 8(길이 정보)을 더한 값을 반환합니다.
함수에 인수가 여러 개 있는 경우 각 인수의 바이트 크기를 합산합니다.
구문
인수
arg1[, arg2, ...]— 압축되지 않은 바이트 크기를 추정할 임의의 데이터 타입 값입니다.Any
반환 값
인수들이 메모리에서 차지하는 바이트 크기를 추정한 값을 반환합니다. UInt64
예시
사용 예시
여러 개의 인수
catboostEvaluate
도입된 버전: v22.9.0
외부 CatBoost 모델을 평가합니다. CatBoost는 Yandex에서 머신 러닝을 위해 개발한 오픈 소스 그래디언트 부스팅 라이브러리입니다. CatBoost 모델의 경로와 모델 매개변수(특징)를 인수로 받습니다.
사전 준비 사항
- CatBoost 평가 라이브러리 빌드
CatBoost 모델을 평가하기 전에 libcatboostmodel.<so|dylib> 라이브러리를 사용할 수 있도록 준비해야 합니다. 이를 컴파일하는 방법은 CatBoost documentation을 참고하십시오.
다음으로, ClickHouse 설정에서 libcatboostmodel.<so|dylib>의 경로를 지정합니다:
보안 및 격리상의 이유로 모델 평가는 서버 프로세스에서 실행되지 않고 clickhouse-library-bridge 프로세스에서 실행됩니다.
catboostEvaluate()를 처음 실행할 때, 라이브러리 브리지 프로세스가 이미 실행 중이 아니면 서버가 해당 프로세스를 시작합니다. 두 프로세스는
HTTP 인터페이스를 사용하여 통신합니다. 기본적으로 포트 9012가 사용됩니다. 포트 9012를 다른 서비스가 이미 사용 중인 경우,
아래와 같이 다른 포트를 지정할 수 있습니다.
- libcatboost를 사용하여 CatBoost 모델 학습
학습 데이터 세트에서 CatBoost 모델을 학습하는 방법은 Training and applying models를 참조하십시오.
구문
인수
path_to_model— CatBoost 모델의 경로입니다.const Stringfeature— 하나 이상의 모델 특성(피처)입니다.Float*
반환 값
모델 평가 결과를 반환합니다. Float64
예시
catboostEvaluate
colorOKLABToSRGB
도입된 버전: v26.2.0
OKLab 지각 색 공간의 색상을 sRGB 색 공간으로 변환합니다.
입력 색상은 OKLab 색 공간에서 지정합니다. 입력 값이 일반적인 OKLab 범위를 벗어나는 경우, 결과는 구현에 따라 달라집니다.
OKLab은 세 가지 구성 요소를 사용합니다:
- L: 지각적 명도(일반적으로 [0..1] 범위)
- a: 녹색-빨간색 대립 축
- b: 파란색-노란색 대립 축
a와 b 구성 요소는 이론적으로는 상한이 없지만, 실제로는 -0.4에서 0.4 사이에 있습니다. OKLab은 계산 비용을 낮게 유지하면서도 지각적으로 균일하도록 설계되었습니다.
이 변환은 colorSRGBToOKLAB의 역변환이 되도록 설계되었으며, 다음 단계로 구성됩니다:
- OKLab에서 선형 sRGB로 변환. 2) 선형 sRGB에서 감마 인코딩된 sRGB로 변환.
선택적 인수인 gamma는 선형 sRGB에서 감마 인코딩된 RGB 값으로 변환할 때 사용하는 지수를 지정합니다. 지정하지 않으면 colorSRGBToOKLAB과의 일관성을 위해 기본 gamma 값이 사용됩니다.
OKLab 색 공간과 sRGB의 관계에 대한 자세한 내용은 https://developer.mozilla.org/en-US/docs/Web/CSS/Reference/Values/color_value/oklab 페이지를 참조하십시오.
구문
인수(Arguments)
tuple— 세 개의 숫자형 값L,a,b로 이루어진 튜플입니다. 여기서L은[0...1]범위에 속하는 값입니다.Tuple(Float64, Float64, Float64)gamma— 선택 사항입니다. 각 채널x에 대해(x ^ (1 / gamma)) * 255를 적용하여 선형 sRGB를 sRGB로 되돌릴 때 사용되는 지수입니다. 기본값은2.2입니다.Float64
반환 값
sRGB 색상 값을 나타내는 튜플 (R, G, B)을 반환합니다. Tuple(Float64, Float64, Float64)
예시
OKLAB을 sRGB(Float)로 변환
OKLAB을 sRGB(UInt8)로 변환
colorOKLCHToSRGB
도입된 버전: v25.7.0
OKLCH 지각 색 공간의 색을 익숙한 sRGB 색 공간으로 변환합니다.
L이 [0...1] 범위를 벗어나거나 C가 음수이거나 H가 [0...360] 범위를 벗어나는 경우 결과는 구현에 따라 달라집니다.
OKLCH는 OKLab 색 공간의 원통형 버전입니다.
세 좌표는 L(밝기, 범위 [0...1]), C(채도, >= 0), H(색상, 도 단위의 [0...360] 범위)입니다.
OKLab/OKLCH는 계산 비용은 낮게 유지하면서도 지각적으로 균일하도록 설계되었습니다.
이 변환은 colorSRGBToOKLCH의 역변환입니다.
- OKLCH에서 OKLab으로 변환 2) OKLab에서 Linear sRGB로 변환 3) Linear sRGB에서 sRGB로 변환
두 번째 인수인 감마(gamma)는 마지막 단계에서 사용합니다.
OKLCH 공간에서의 색상과 그것이 sRGB 색상에 어떻게 대응하는지에 대해서는 https://oklch.com/을 참고하십시오.
구문
인수(Arguments)
tuple— 세 개의 수치 값L,C,H로 이루어진 튜플입니다. 여기서L은[0...1]범위에 있고,C >= 0이며,H는[0...360]범위에 있습니다.Tuple(Float64, Float64, Float64)gamma— 선택 인수입니다. 선형 sRGB를 각 채널x에 대해(x ^ (1 / gamma)) * 255를 적용하여 sRGB로 다시 변환하는 데 사용되는 지수입니다. 기본값은2.2입니다.Float64
반환 값
sRGB 색상 값을 나타내는 튜플 (R, G, B)를 반환합니다. Tuple(Float64, Float64, Float64)
예시
OKLCH를 sRGB로 변환하기
OKLCH를 sRGB(UInt8)로 변환
colorSRGBToOKLAB
도입 버전: v26.2.0
sRGB 색 공간으로 인코딩된 색상을 지각적으로 균일한 OKLAB 색 공간으로 변환합니다.
입력 채널 중 하나라도 [0...255] 범위를 벗어나거나 감마 값이 0 이하인 경우 동작은 구현에 따라 달라집니다.
OKLAB은 지각적으로 균일한 색 공간입니다.
세 좌표는 L(밝기, 범위 [0...1]), a(초록-빨강 축) 및 b(파랑-노랑 축)입니다.
OKLab은 계산 비용을 낮게 유지하면서도 지각적으로 균일하도록 설계되었습니다.
변환은 두 단계로 구성됩니다:
- sRGB에서 Linear sRGB로 변환 2) Linear sRGB에서 OKLab으로 변환
구문
인수
tuple—[0...255]범위의 R, G, B 세 값으로 구성된 튜플입니다.Tuple(UInt8, UInt8, UInt8)gamma— 선택 사항입니다. 각 채널x에(x / 255)^gamma를 적용하여 sRGB를 선형화하는 데 사용되는 지수입니다. 기본값은2.2입니다.Float64
반환 값
OKLAB 색 공간 값을 나타내는 튜플 (L, a, b)을 반환합니다. Tuple(Float64, Float64, Float64)
예시
sRGB를 OKLAB으로 변환
colorSRGBToOKLCH
도입된 버전: v25.7.0
sRGB 색 공간으로 인코딩된 색상을 지각적으로 균일한 OKLCH 색 공간으로 변환합니다.
입력 채널 중 하나라도 [0...255] 범위를 벗어나거나 감마 값이 양수가 아닌 경우, 동작은 구현에 따라 정의됩니다.
OKLCH는 OKLab 색 공간의 원통형 버전입니다.
세 좌표는 L(밝기, 범위 [0...1]), C(채도, >= 0), H(색상, 도 단위 [0...360] 범위)입니다.
OKLab/OKLCH는 계산 비용을 낮게 유지하면서도 지각적으로 균일하도록 설계되었습니다.
변환은 다음 세 단계로 구성됩니다.
- sRGB에서 Linear sRGB로 변환 2) Linear sRGB에서 OKLab으로 변환 3) OKLab에서 OKLCH로 변환
OKLCH 공간에서의 색상과 해당 색상이 sRGB 색상과 어떻게 대응하는지에 대한 참고 자료는 https://OKLCH.com/을 참조하십시오.
구문
인수
tuple—[0...255]범위의 R, G, B 세 값으로 구성된 튜플입니다.Tuple(UInt8, UInt8, UInt8)gamma— 선택적 인수입니다. 각 채널x에(x / 255)^gamma를 적용하여 sRGB를 선형화하는 데 사용되는 지수입니다. 기본값은2.2입니다.Float64
반환 값
OKLCH 색 공간 값을 나타내는 (L, C, H) 튜플을 반환합니다. Tuple(Float64, Float64, Float64)
예제
sRGB를 OKLCH로 변환
connectionId
도입된 버전: v21.3.0
현재 쿼리를 전송한 클라이언트의 연결 ID를 반환합니다.
이 함수는 디버깅 시에 가장 유용합니다.
MySQL의 CONNECTION_ID 함수와의 호환성을 위해 만들어졌습니다.
일반적으로 운영 환경의 쿼리에서는 사용되지 않습니다.
구문
인수
- 없음.
반환 값
현재 클라이언트의 연결 ID를 반환합니다. 반환 타입은 UInt64입니다.
예시
사용 예시
countDigits
도입 버전: v20.8.0
값을 표현하는 데 필요한 십진 자릿수의 개수를 반환합니다.
이 FUNCTION은 십진 값의 스케일을 고려합니다. 즉, (value * scale)로 표현되는 기본 정수 타입을 기준으로 결과를 계산합니다.
예를 들어 다음과 같습니다.
countDigits(42) = 2countDigits(42.000) = 5countDigits(0.04200) = 4
Decimal64에 대해 countDigits(x) > 18을 사용하여 십진 오버플로를 확인할 수 있습니다.
다만, isDecimalOverflow보다 느립니다.
구문
인수
반환 값
x를 표현하는 데 필요한 자릿수(숫자 개수)를 반환합니다. UInt8
예시
사용 예시
currentDatabase
도입 버전: v1.1.0
현재 데이터베이스의 이름을 반환합니다.
데이터베이스를 지정해야 하는 CREATE TABLE 쿼리의 테이블 엔진 매개변수에서 유용합니다.
SET SQL 문도 참조하십시오.
구문
별칭: current_database, SCHEMA, DATABASE
인수
- 없음.
반환 값
현재 데이터베이스의 이름을 반환합니다. String
예시
사용 예
괄호 없는 SQL 표준 구문
currentProfiles
도입된 버전: v21.9.0
현재 사용자에게 적용된 설정 프로파일 배열을 반환합니다.
구문
인수
- 없음.
반환 값
현재 사용자에 대한 설정 프로필의 배열을 반환합니다. Array(String)
예제
사용 예제
currentQueryID
도입된 버전: v25.2.0
현재 쿼리 ID를 반환합니다.
구문
별칭: current_query_id
인수
- 없음
반환값
예시
예시
currentRoles
도입 버전: v21.9.0
현재 사용자에게 할당된 역할 배열을 반환합니다.
구문
인수
- 없음.
반환값
현재 사용자에게 할당된 역할의 배열을 반환합니다. Array(String)
예시
사용 예시
currentSchemas
도입: v23.7.0
함수 currentDatabase와 동일하지만,
- 무시되는 boolean 인수를 하나 허용하며
- 단일 값이 들어 있는 배열로 데이터베이스 이름을 반환합니다.
currentSchemas 함수는 PostgreSQL과의 호환성만을 위해 존재합니다.
대신 currentDatabase를 사용하십시오.
또한 SET SQL 문을(를) 참고하십시오.
구문
별칭(Aliases): current_schemas
인수(Arguments)
bool— 사용되지 않는 Boolean 값입니다.Bool
반환 값(Returned value)
현재 데이터베이스 이름을 요소로 하는 단일 요소 배열을 반환합니다. Array(String)
예시(Examples)
사용 예시(Usage example)
currentUser
도입된 버전: v20.1.0
현재 사용자의 이름을 반환합니다. 분산 쿼리인 경우 쿼리를 시작한 사용자의 이름을 반환합니다.
Syntax
별칭: current_user, user
인수
- 없음.
반환 값
현재 사용자의 이름을 반환하며, 그렇지 않으면 쿼리를 시작한 사용자의 로그인을 반환합니다. String
예시
사용 예시
괄호 없이 사용하는 SQL 표준 구문
defaultProfiles
도입된 버전: v21.9.0
현재 사용자의 기본 설정 프로필 이름 배열을 반환합니다.
구문
인수
- 없음.
반환 값
현재 사용자에 대한 기본 설정 프로필 이름의 배열을 반환합니다. Array(String)
예시
사용 예시
defaultRoles
도입된 버전: v21.9.0
현재 사용자에 대해 설정된 기본 역할의 배열을 반환합니다.
구문
인수
- 없음.
반환값
현재 사용자에 대해 설정된 기본 역할의 배열을 반환합니다. Array(String)
예
사용 예
defaultValueOfArgumentType
도입된 버전: v1.1.0
주어진 데이터 타입의 기본값을 반환합니다. 사용자가 설정한 사용자 정의 컬럼의 기본값은 포함하지 않습니다.
구문
인수
expression— 임의 타입의 값 또는 임의 타입의 값으로 평가되는 표현식.Any
반환 값
숫자에는 0, 문자열에는 빈 문자열, 널 허용(Nullable) 타입에는 NULL을 반환합니다. UInt8 또는 String 또는 NULL
예시
사용 예시
널 허용 예제
defaultValueOfTypeName
도입 버전: v1.1.0
지정된 타입 이름의 기본값을 반환합니다.
구문
인수
type— 타입 이름을 나타내는 문자열입니다.String
반환 값
지정된 타입 이름에 대한 기본값을 반환합니다. 숫자 타입의 경우 0, 문자열 타입의 경우 빈 문자열, 널 허용 UInt8 또는 String 또는 NULL 타입의 경우 NULL을 반환합니다.
예시
사용 예시
널 허용 예시
displayName
도입 버전: v22.11.0
config의 display_name 값이 설정되어 있으면 해당 값을, 설정되지 않았다면 서버의 FQDN(Fully Qualified Domain Name, 정규화된 도메인 이름)을 반환합니다.
구문
인수
- 없음.
반환 값
구성(config)의 display_name 값 또는 설정되지 않은 경우 서버 FQDN 값을 반환합니다. String
예시
사용 예시
dumpColumnStructure
도입 버전: v1.1.0
컬럼의 내부 구조와 데이터 타입을 자세히 출력합니다.
구문
인수
x— 설명을 가져올 대상 값입니다.Any
반환 값
값을 표현하는 데 사용되는 컬럼 구조에 대한 설명을 반환합니다. String
예시
사용 예시
enabledProfiles
도입 버전: v21.9.0
현재 사용자에게 활성화되어 있는 설정 프로파일 이름의 배열을 반환합니다.
구문
인수
- 없음.
반환 값
현재 사용자에게 활성화된 설정 프로필 이름의 배열을 반환합니다. Array(String)
예시
사용 예시
enabledRoles
도입된 버전: v21.9.0
현재 사용자에게 활성화된 역할의 배열을 반환합니다.
구문
인수
- 없음.
반환 값
현재 사용자에게 활성화된 역할 이름들의 배열을 반환합니다. Array(String)
예시
사용 예시
errorCodeToName
도입 버전: v20.12.0
숫자형 ClickHouse 오류 코드에 대한 이름(문자열)을 반환합니다. 숫자형 오류 코드와 오류 이름 간의 매핑은 여기에서 확인할 수 있습니다.
구문
인수
반환값
error_code의 텍스트 형태 이름을 반환합니다. String
예시
사용 예시
file
도입된 버전: v21.3.0
파일을 문자열로 읽어서 지정된 컬럼에 데이터를 로드합니다. 파일 내용은 해석되지 않습니다.
file 테이블 함수도 참고하십시오.
구문
인수
path—user_files_path를 기준으로 한 파일의 경로입니다. 와일드카드*,**,?,{abc,def},{N..M}을(를) 지원합니다. 여기서N,M은 숫자이고'abc', 'def'는 문자열입니다.Stringdefault— 파일이 존재하지 않거나 접근할 수 없을 때 반환되는 값입니다.String또는NULL
반환 값
파일 내용을 문자열로 반환합니다. String
예시
파일을 테이블에 삽입
filesystemAvailable
도입 버전: v20.1.0
데이터베이스 영구 저장소를 호스팅하는 파일 시스템에서 사용 가능한 여유 공간의 양을 반환합니다.
운영 체제를 위해 일부 공간이 예약되므로, 반환되는 값은 항상 파일 시스템의 전체 여유 공간(filesystemUnreserved)보다 작습니다.
구문
인자
disk_name— 선택 사항입니다. 사용 가능한 여유 공간을 조회할 디스크 이름입니다. 생략하면 기본 디스크가 사용됩니다.String또는FixedString
반환 값
사용 가능한 남은 공간의 크기를 바이트 단위로 반환합니다. UInt64
예시
사용 예시
filesystemCapacity
도입된 버전: v20.1.0
파일 시스템의 총 용량을 바이트 단위로 반환합니다. 데이터 디렉터리의 path가 설정되어 있어야 합니다.
구문
인수
disk_name— 선택 사항입니다. 용량을 확인할 디스크 이름입니다. 생략하면 기본 디스크를 사용합니다.String또는FixedString
반환 값
파일 시스템의 용량을 바이트 단위로 반환합니다. UInt64
예시
사용 예시
filesystemUnreserved
도입 버전: v22.12.0
데이터베이스 영구 저장소를 호스팅하는 파일 시스템의 총 여유 공간(이전 이름: filesystemFree)을 반환합니다.
filesystemAvailable도 참조하십시오.
구문
인수
disk_name— 선택 사항입니다. 총 여유 공간을 확인할 디스크 이름입니다. 생략하면 기본 디스크를 사용합니다.String또는FixedString
반환 값
여유 공간의 크기를 바이트 단위로 반환합니다. UInt64
예시
사용 예시
finalizeAggregation
도입 버전: v1.1.0
집계 상태를 입력으로 받아, 이 함수는 집계 결과(또는 -State 콤비네이터를 사용할 때는 최종화된 상태)를 반환합니다.
구문
인수
state— 집계의 상태입니다.AggregateFunction
반환값
집계가 완료된 최종 결과를 반환합니다. Any
예시
사용 예시
initializeAggregation과 함께 사용
flipCoordinates
도입 버전: v25.10.0
기하 객체의 x, y 좌표를 뒤바꿉니다. 이 연산은 위도와 경도를 서로 바꾸므로, 서로 다른 좌표계 간 변환이나 좌표 순서 교정에 유용합니다.
Point의 경우 x, y 좌표를 서로 바꿉니다. 복합 기하 객체(LineString, Polygon, MultiPolygon, Ring, MultiLineString)의 경우, 각 좌표 쌍에 대해 재귀적으로 이 변환을 적용합니다.
이 FUNCTION은 개별 기하 타입(Point, Ring, Polygon, MultiPolygon, LineString, MultiLineString)과 Geometry variant 타입 모두를 지원합니다.
구문
인수
geometry— 변환할 geometry입니다. 지원되는 타입: Point (Tuple(Float64, Float64)), Ring (Array(Point)), Polygon (Array(Ring)), MultiPolygon (Array(Polygon)), LineString (Array(Point)), MultiLineString (Array(LineString)), Geometry (이들 타입 중 하나를 포함하는 variant).
반환값
좌표가 뒤바뀐 geometry입니다. 반환 타입은 입력 타입과 동일합니다. Point, Ring, Polygon, MultiPolygon, LineString, MultiLineString, Geometry
예시
basic_point
ring
다각형
geometry_wkt
geometry_polygon_wkt
formatQuery
도입 버전: v23.10.0
지정된 SQL 쿼리를 포맷팅한 버전(여러 줄이 될 수 있음)을 반환합니다. 구문 분석 오류가 발생하면 예외를 던집니다. [example:multiline]
구문
인자
query— 포맷할 SQL 쿼리입니다. String
반환 값
포맷된 쿼리 String
예시
multiline
formatQueryOrNull
도입된 버전: v23.11.0
지정된 SQL 쿼리를 서식화한 문자열을 반환하며, 이 문자열은 여러 줄로 구성될 수 있습니다. 구문 분석 오류가 발생한 경우 NULL을 반환합니다. [example:multiline]
구문
인수
query— 포맷할 SQL 쿼리입니다. String
반환값
포맷된 쿼리 String
예시
여러 줄
formatQuerySingleLine
도입 버전: v23.10.0
formatQuery()와 유사하지만, 반환되는 포맷된 문자열에는 개행 문자가 포함되지 않습니다. 파싱 오류가 발생하면 예외를 던집니다. [example:multiline]
구문
인수
query— 포맷할 SQL 쿼리입니다. String
반환값
포맷된 쿼리 String
예시
multiline
formatQuerySingleLineOrNull
도입 버전: v23.11.0
formatQuery()와 유사하지만, 반환되는 포맷된 문자열에는 줄 바꿈이 포함되지 않습니다. 구문 분석 오류가 발생한 경우 NULL을 반환합니다. [example:multiline]
구문
인수
query— 서식을 지정할 SQL 쿼리입니다.String
반환 값
서식이 지정된 쿼리 String
예시
multiline
formatReadableDecimalSize
도입 버전: v22.11.0
바이트 단위 크기(바이트 수)를 입력하면, 이 FUNCTION은 접미사(KB, MB 등)가 포함된 사람이 읽기 쉬운 반올림된 크기를 문자열로 반환합니다.
이 FUNCTION의 역연산 FUNCTION은 parseReadableSize입니다.
구문
인수
x— 바이트 단위 크기.UInt64
반환 값
접미사가 포함된 사람이 읽기 쉬운 형식의 반올림된 크기를 문자열로 반환합니다. String
예시
파일 크기 형식 지정
formatReadableQuantity
도입 버전: v20.10.0
숫자를 입력하면 이 함수는 반올림된 숫자에 접미사(천, 백만, 십억 등)를 붙인 문자열을 반환합니다.
이 함수는 모든 숫자형 타입을 입력으로 받지만, 내부적으로는 Float64로 캐스팅합니다.
값이 매우 큰 경우 결과가 최적이 아닐 수 있습니다.
구문
인수
x— 형식을 지정할 숫자.UInt64
반환 값
접미사가 포함된 반올림된 숫자를 문자열로 반환합니다. String
예시
접미사를 사용하여 숫자 형식 지정하기
formatReadableSize
도입 버전: v1.1.0
바이트 단위 크기를 입력하면, 이 함수는 접미사(KiB, MiB 등)가 포함된 사람이 읽기 쉬운 반올림된 크기를 문자열로 반환합니다.
이 함수의 역 연산은 parseReadableSize, parseReadableSizeOrZero, parseReadableSizeOrNull입니다.
이 함수는 입력으로 임의의 숫자형 데이터 타입을 허용하지만, 내부적으로는 이를 Float64로 캐스팅합니다. 값이 매우 큰 경우 결과가 최적이 아닐 수 있습니다.
Syntax
별칭: FORMAT_BYTES
인수
x— 바이트 단위의 크기.UInt64
반환 값
크기를 읽기 쉬운 형태로 반올림하고 단위를 접미사로 붙인 문자열을 반환합니다. String
예시
파일 크기 형식 지정
formatReadableTimeDelta
도입 버전: v20.12.0
초 단위의 시간 간격(delta)이 주어지면, 이 함수는 연/월/일/시/분/초/밀리초/마이크로초/나노초 단위로 표현된 시간 차이를 문자열로 반환합니다.
이 함수는 입력으로 임의의 숫자형 데이터 타입을 허용하지만, 내부적으로는 Float64로 캐스팅합니다. 매우 큰 값에 대해서는 결과가 최적이지 않을 수 있습니다.
구문
인수
column— 시간 차이를 나타내는 숫자형 컬럼입니다.Float64maximum_unit— 선택 사항입니다. 표시할 최대 단위입니다. 허용되는 값:nanoseconds,microseconds,milliseconds,seconds,minutes,hours,days,months,years. 기본값:years.const Stringminimum_unit— 선택 사항입니다. 표시할 최소 단위입니다. 이보다 작은 모든 단위는 절사됩니다. 허용되는 값:nanoseconds,microseconds,milliseconds,seconds,minutes,hours,days,months,years. 명시적으로 지정한 값이maximum_unit보다 크면 예외가 발생합니다. 기본값:maximum_unit이seconds이상이면seconds, 그렇지 않으면nanoseconds입니다.const String
반환 값
시간 차이를 문자열로 반환합니다. String
예시
사용 예시
최대 단위 기준
fuzzQuery
도입: v26.2.0
지정된 쿼리 문자열을 파싱한 뒤, AST에 임의의 뮤테이션(퍼징)을 적용합니다. 퍼징된 쿼리를 문자열로 반환합니다. 비결정적인 동작이므로 호출할 때마다 서로 다른 결과가 생성될 수 있습니다. allow_fuzz_query_functions = 1 설정이 필요합니다.
구문
인수
query— 퍼징(fuzzing)을 적용할 SQL 쿼리입니다. String
반환 값
퍼징된 쿼리를 나타내는 쿼리 문자열 String
예시
기본
generateRandomStructure
도입 버전: v23.5.0
column1_name column1_type, column2_name column2_type, ... 형식의 무작위 테이블 구조를 생성합니다.
구문
인수
number_of_columns— 결과 테이블 구조에서 원하는 컬럼 수입니다. 0 또는Null로 설정하면 컬럼 수는 1에서 128 사이에서 임의로 결정됩니다. 기본값:Null.UInt64seed— 결과를 안정적으로 재현하기 위한 난수 시드입니다. 시드를 지정하지 않거나Null로 설정하면, 임의로 생성됩니다.UInt64
반환 값
임의로 생성된 테이블 구조입니다. String
예시
사용 예시
지정된 컬럼 개수로
지정된 시드 사용
generateSerialID
도입된 버전: v25.1.0
이전 카운터 값부터 시작하는 연속된 숫자를 생성하여 반환합니다.
이 함수는 문자열 인자를 사용하며, 시리즈 식별자와 선택적인 시작 값을 인자로 받습니다.
서버에는 Keeper가 구성되어 있어야 합니다.
시리즈는 서버 설정의 series_keeper_path에서 구성할 수 있는 경로 아래의 Keeper 노드에 저장됩니다.
구문
인수
series_identifier— 시리즈 식별자const Stringstart_value— 선택 사항입니다. 카운터의 시작 값입니다. 기본값은 0입니다. 참고: 이 값은 새 시리즈를 생성할 때만 사용되며, 시리즈가 이미 존재하는 경우에는 무시됩니다.UInt*
반환 값
이전 카운터 값 다음부터 시작하는 연속된 숫자를 반환합니다. UInt64
예시
첫 번째 호출
두 번째 호출
컬럼 단위 호출
시작 값 지정
시작 값을 지정한 두 번째 호출
getClientHTTPHeader
도입 버전: v24.5.0
HTTP 헤더의 값을 가져옵니다.
해당 헤더가 없거나 현재 요청이 HTTP 인터페이스를 통해 수행되는 요청이 아닌 경우, 함수는 빈 문자열을 반환합니다.
일부 HTTP 헤더(예: Authentication 및 X-ClickHouse-*)는 제한되어 있습니다.
allow_get_client_http_header 설정이 필요함이 함수를 사용하려면 allow_get_client_http_header 설정이 활성화되어 있어야 합니다.
Cookie와 같이 민감한 정보를 포함할 수 있는 헤더가 있기 때문에, 보안상의 이유로 이 설정은 기본적으로 비활성화되어 있습니다.
이 함수에서 HTTP 헤더는 대소문자를 구분합니다. 함수가 분산 쿼리 환경에서 사용되는 경우, 쿼리를 시작한 이니시에이터 노드(initiator node)에서만 비어 있지 않은 결과를 반환합니다.
Syntax
인수
name— HTTP 헤더의 이름.String
반환값
헤더 값을 반환합니다. String
예시
사용 예시
getMacro
도입 버전: v20.1.0
서버 구성 파일에서 매크로의 값을 반환합니다.
매크로는 구성 파일의 <macros> 섹션에 정의되며, 호스트명이 복잡하더라도 서버를 구분하기 쉬운 이름으로 식별하는 데 사용할 수 있습니다.
함수가 분산 테이블 컨텍스트에서 실행되면 각 세그먼트에 해당하는 값을 가지는 일반 컬럼을 생성합니다.
구문
인수
name— 가져올 매크로의 이름입니다.const String
반환 값
지정된 매크로의 값을 반환합니다. String
예제
기본 사용법
getMaxTableNameLengthForDatabase
도입 버전: v25.1.0
지정된 데이터베이스에서 허용되는 최대 테이블 이름 길이를 반환합니다.
구문
매개변수
database_name— 지정된 데이터베이스의 이름입니다.String
반환 값
가장 긴 테이블 이름의 길이를 Integer 값으로 반환합니다.
예시
일반적인 사용 예
getMergeTreeSetting
도입된 버전: v25.6.0
현재 MergeTree 설정 값을 반환합니다.
구문
인수
setting_name— 설정 이름입니다.String
반환 값
MergeTree 설정의 현재 값을 반환합니다.
예시
사용 예시
getOSKernelVersion
도입 버전: v21.11.0
OS 커널 버전을 나타내는 문자열을 반환합니다.
구문
인수
- 없음.
반환값
현재 OS 커널 버전을 반환합니다. String
예제
사용 예제
getServerPort
도입 버전: v21.10.0
지정된 프로토콜에 해당하는 서버의 포트 번호를 반환합니다.
구문
인수
port_name— 포트의 이름입니다.String
반환값
서버 포트 번호를 반환합니다. UInt16
예제
사용 예제
getServerSetting
도입된 버전: v25.6.0
서버 설정 이름을 지정하면 해당 설정의 현재 값을 반환합니다.
구문
인수
setting_name— 서버 설정의 이름입니다.String
반환값
서버 설정의 현재 값을 반환합니다. Any
예제
사용 예제
getSetting
도입 버전: v20.7.0
현재 설정값을 반환합니다.
구문
인수
setting_Name— 설정 이름입니다.const String
반환 값
설정의 현재 값을 반환합니다. Any
예시
사용 예시
getSettingOrDefault
도입 버전: v24.10.0
현재 설정 값이 있으면 해당 값을 반환하고, 현재 프로필에 해당 설정이 지정되어 있지 않으면 두 번째 인수로 지정된 기본값을 반환합니다.
구문
인수
setting_name— 설정 이름.Stringdefault_value—custom_setting이 설정되지 않은 경우 반환할 값입니다. 값은 임의의 데이터 타입이거나 Null일 수 있습니다.
반환 값
지정된 설정의 현재 값을 반환하거나, 해당 설정이 설정되지 않은 경우 default_value를 반환합니다.
예시
사용 예시
getSizeOfEnumType
도입: v1.1.0
주어진 Enum에 포함된 필드 수를 반환합니다.
구문
인수
x—Enum유형의 값입니다.Enum
반환 값
Enum 입력 값을 가진 필드 수를 반환합니다. UInt8/16
예시
사용 예시
getSubcolumn
도입된 버전: v23.3.0
식 또는 식별자, 그리고 하위 컬럼 이름을 나타내는 상수 문자열을 인수로 받습니다.
식에서 지정된 하위 컬럼을 추출하여 반환합니다.
구문
인수
- 없음.
반환 값
예시
getSubcolumn
getTypeSerializationStreams
도입된 버전: v22.6.0
데이터 타입의 스트림 경로를 나열합니다. 이 FUNCTION은 개발 목적으로 사용하도록 설계되었습니다.
구문
인수
col— 데이터 타입을 감지할 컬럼 또는 데이터 타입의 문자열 표현입니다.Any
반환 값
모든 직렬화 서브스트림 경로를 포함하는 배열을 반환합니다. Array(String)
예제
tuple
맵
globalVariable
도입된 버전: v20.5.0
상수 문자열 인자를 받아 해당 이름의 전역 변수 값을 반환합니다. 이 FUNCTION은 MySQL과의 호환성을 위한 것이며, 일반적인 ClickHouse 운영에서는 필요하지도 유용하지도 않습니다. 일부 더미 전역 변수만 정의되어 있습니다.
구문
인수
name— 전역 변수 이름.String
반환 값
변수 name의 값을 반환합니다. Any
예시
globalVariable
hasColumnInTable
도입 버전: v1.1.0
특정 컬럼이 데이터베이스 테이블에 존재하는지 확인합니다.
중첩 데이터 구조의 요소인 경우, 함수는 해당 컬럼이 존재하는지 확인합니다.
중첩 데이터 구조 자체인 경우, 함수는 0을 반환합니다.
구문
인수
database— 데이터베이스 이름.const Stringtable— 테이블 이름.const Stringcolumn— 컬럼 이름.const Stringhostname— 선택 사항. 검사를 수행할 원격 서버 이름.const Stringusername— 선택 사항. 원격 서버의 사용자 이름.const Stringpassword— 선택 사항. 원격 서버의 비밀번호.const String
반환 값
지정된 컬럼이 존재하면 1, 그렇지 않으면 0을 반환합니다. UInt8
예시
존재하는 컬럼을 확인
존재하지 않는 컬럼을 확인
hasThreadFuzzer
도입 버전: v20.6.0
thread fuzzer가 활성화되어 있는지 여부를 반환합니다. 이 함수는 테스트와 디버깅에만 유용합니다.
구문
인수(Arguments)
- 없음.
반환값
Thread Fuzzer가 활성화되어 있는지 여부를 반환합니다. UInt8
예제(Examples)
Thread Fuzzer 상태 확인
hostName
도입된 버전: v20.5.0
이 함수가 실행된 호스트 이름을 반환합니다. 함수가 원격 서버에서 실행되면(분산 처리) 원격 서버 이름을 반환합니다. 함수가 분산 테이블 컨텍스트에서 실행되면, 각 세그먼트와 관련된 값을 가진 일반 컬럼을 생성합니다. 그 외의 경우에는 상수 값을 반환합니다.
구문
별칭(Aliases): hostname
인수(Arguments)
- 없음.
반환값(Returned value)
호스트 이름을 반환합니다. String
예제(Examples)
사용 예제(Usage example)
icebergBucket
도입된 버전: v25.5.0
iceberg bucket transform에 대한 로직을 구현합니다.
구문
인수
N— 버킷 개수(모듈로 값).const (U)Int*value— 변환할 원본 값.(U)Int*또는Bool또는Decimal또는Float*또는String또는FixedString또는UUID또는Date또는Time또는DateTime
반환 값
원본 값에 대한 32비트 해시를 반환합니다. Int32
예제
예제
icebergTruncate
도입된 버전: v25.3.0
Iceberg truncate 변환(transform)의 로직을 구현합니다: https://iceberg.apache.org/spec/#truncate-transform-details.
구문
인수
반환값
인수와 동일한 타입입니다.
예제
예제
identity
도입된 버전: v1.1.0
이 함수는 전달된 인수를 그대로 반환하며, 디버깅과 테스트에 유용합니다. 인덱스 사용을 우회하여 전체 스캔 시의 성능을 확인할 수 있습니다. 쿼리 분석기는 사용할 인덱스를 찾을 때 identity 함수 내부의 모든 내용을 무시하며, 상수 폴딩도 비활성화합니다.
구문
인수
x— 입력값.Any
반환 값
입력값을 변경하지 않고 그대로 반환합니다. Any
예시
사용 예시
ignore
도입: v1.1.0
임의의 인자를 받아들여 무조건 0을 반환합니다.
구문
인수
x— 구문 오류를 피하기 위해서만 전달되는, 실제로는 사용되지 않는 입력 값입니다.Any
반환 값
항상 0을 반환합니다. UInt8
예시
사용 예시
indexHint
도입 버전: v1.1.0
이 함수는 디버깅과 내부 상태 확인을 위한 것입니다. 인자를 무시하고 항상 1을 반환합니다. 인자는 평가되지 않습니다.
인덱스 분석 중에는 이 함수의 인자가 indexHint로 감싸져 있지 않은 것으로 가정합니다.
이를 통해 해당 조건으로 인덱스 범위 내 데이터를 선택하되, 이후 이 조건으로 추가 필터링하지 않을 수 있습니다.
ClickHouse의 인덱스는 희소 인덱스이며, indexHint를 사용하면 동일한 조건을 직접 지정했을 때보다 더 많은 데이터를 반환합니다.
Explanation
다음과 같이 실행하면:
ClickHouse는 두 가지 작업을 수행합니다:
- 인덱스를 사용해 어떤 그래뉼(약 8,192개의 행으로 이루어진 블록)에
key = 123이 포함될 수 있는지 찾습니다. - 해당 그래뉼들을 읽어, 그 안에서
key = 123인 행만 남기도록 행 단위로 필터링합니다.
따라서 디스크에서 8,192개의 행을 읽더라도 실제로 일치하는 1개의 행만 반환합니다.
indexHint를 사용해 다음과 같이 실행하면:
ClickHouse는 한 가지 작업만 수행합니다:
- 인덱스를 사용해 어떤 그래뉼에 key = 123이 포함될 수 있는지 찾고, 해당 그래뉼에 있는 모든 행을 필터링 없이 그대로 반환합니다.
이렇게 하면 key = 456, key = 789 등도 포함하여, 해당 그래뉼에 우연히 저장되어 있던 모든 행, 즉 8,192개의 행을 모두 반환합니다.
indexHint()는 성능을 위한 기능이 아닙니다. ClickHouse의 인덱스가 어떻게 동작하는지 디버깅하고 이해하기 위한 기능입니다:
- 내 조건이 어떤 그래뉼을 선택하는가?
- 그 그래뉼들에는 몇 개의 행이 있는가?
- 인덱스가 효과적으로 사용되고 있는가?
주의: indexHint 함수를 사용하여 쿼리를 최적화하는 것은 불가능합니다. indexHint 함수는 쿼리 분석에 추가 정보를 제공하지 않기 때문에 쿼리를 최적화하지 않습니다. indexHint 함수 안에 표현식을 넣어도 indexHint 함수 없이 사용할 때보다 나아지는 점은 전혀 없습니다. indexHint 함수는 내부 상태 확인과 디버깅 목적에만 사용할 수 있으며 성능을 향상시키지 않습니다. ClickHouse 기여자가 아닌 사람이 indexHint를 사용하는 것을 보게 되면, 그 사용은 대개 실수일 가능성이 높으며 제거하는 것이 좋습니다.
문법
인수
expression— 인덱스 범위 선택을 위한 임의의 식.Expression
반환 값
모든 경우에 1을 반환합니다. UInt8
예시
날짜 필터링을 사용하는 사용 예시
initialQueryID
도입 버전: v1.1.0
초기(원본) 현재 쿼리의 ID를 반환합니다.
쿼리의 다른 매개변수는 system.query_log의 initial_query_id 필드에서 추출할 수 있습니다.
queryID 함수와는 달리 initialQueryID는 서로 다른 세그먼트에서도 동일한 결과를 반환합니다.
구문
별칭: initial_query_id
인수
- 없음.
반환 값
현재 실행 중인 최초 쿼리의 ID를 반환합니다. String
예시
사용 예시
initialQueryStartTime
도입된 버전: v25.4.0
초기 쿼리의 시작 시간을 반환합니다.
initialQueryStartTime는 서로 다른 세그먼트에서도 동일한 결과를 반환합니다.
구문
별칭: initial_query_start_time
인수
- 없음.
반환 값
현재 쿼리의 최초 시작 시간을 반환합니다. DateTime
예시
사용 예시
initializeAggregation
도입 버전: v20.6.0
단일 값을 기반으로 집계 함수의 결과를 계산합니다.
이 함수는 -State 컴비네이터가 있는 집계 함수를 초기화하는 데 사용할 수 있습니다.
집계 함수의 상태를 생성하여 AggregateFunction 타입의 컬럼에 삽입하거나, 초기화된 집계를 기본값으로 사용할 수 있습니다.
문법
인수
반환값
함수에 전달된 각 행에 대한 집계 결과를 반환합니다. 반환 타입은 initializeAggregation이 첫 번째 인수로 받는 함수의 반환 타입과 동일합니다. Any
예시
uniqState의 기본 사용 예시
sumState 및 finalizeAggregation과 함께 사용하기
isConstant
도입된 버전: v20.3.0
인수가 상수 표현식인지 여부를 반환합니다. 상수 표현식은 실행 이전, 즉 쿼리 분석 중에 결과를 알 수 있는 표현식입니다. 예를 들어, 리터럴을 사용한 표현식은 상수 표현식입니다. 이 함수는 주로 개발, 디버깅 및 시연 용도로 사용됩니다.
구문
인자
x— 검사할 표현식입니다.Any
반환 값
x가 상수이면 1을, 상수가 아니면 0을 반환합니다. UInt8
예시
상수 표현식
FUNCTION을 사용한 상수
상수가 아닌 표현식
now() 함수의 동작
isDecimalOverflow
도입 버전: v20.8.0
지정된 정밀도(precision)를 가진 Decimal 데이터 타입에 정상적으로 저장될 수 있는 자릿수 범위를 초과하는지 확인합니다.
구문
인수(Arguments)
value— 검사할 Decimal 값입니다.Decimalprecision— 선택적 인수입니다. Decimal 타입의 정밀도입니다. 생략하면 첫 번째 인수의 초기 정밀도가 사용됩니다.UInt8
반환 값(Returned value)
Decimal 값의 자릿수가 정밀도에서 허용된 자릿수보다 크면 1, 지정된 정밀도를 만족하면 0을 반환합니다. UInt8
예시(Examples)
사용 예시(Usage example)
joinGet
도입된 버전: v18.16.0
딕셔너리에서 데이터를 추출하는 것과 동일한 방식으로 테이블에서 데이터를 추출할 수 있습니다. 지정된 조인 키를 사용하여 Join 테이블에서 데이터를 가져옵니다.
ENGINE = Join(ANY, LEFT, <join_keys>) 구문으로 생성된 테이블만 지원합니다.
구문
인수
join_storage_table_name— 검색을 수행할 위치를 나타내는 식별자입니다. 이 식별자는 기본 데이터베이스에서 검색됩니다(설정 파일의default_database파라미터 참고). 기본 데이터베이스를 변경하려면USE database_name쿼리를 사용하거나database_name.table_name과 같이 점(.)을 사용하여 데이터베이스와 테이블을 지정합니다.Stringvalue_column— 필요한 데이터가 포함된 테이블 컬럼의 이름입니다.const Stringjoin_keys— 조인 키 목록입니다.Any
반환 값
키 목록에 대응하는 값 목록을 반환합니다. Any
예시
사용 예시
현재 데이터베이스 내 테이블 사용
배열을 조인 키로 활용하기
joinGetOrNull
도입 버전: v20.4.0
딕셔너리에서 데이터를 추출하는 것과 같은 방식으로 테이블에서 데이터를 추출할 수 있습니다.
지정된 조인 키(join key)를 사용하여 Join 테이블에서 데이터를 가져옵니다.
joinGet과 달리, 키가 없으면 NULL을 반환합니다.
ENGINE = Join(ANY, LEFT, <join_keys>) statement로 생성된 테이블만 지원합니다.
구문
인자
join_storage_table_name— 검색을 수행할 위치를 나타내는 식별자입니다. 이 식별자는 기본 데이터베이스에서 검색됩니다(설정 파일의default_database파라미터 참조). 기본 데이터베이스를 변경하려면USE database_name쿼리를 사용하거나database_name.table_name과 같이 점으로 구분하여 데이터베이스와 테이블을 지정합니다.Stringvalue_column— 필요한 데이터를 포함하는 테이블의 컬럼 이름입니다.const Stringjoin_keys— 조인 키 목록입니다.Any
반환 값
키 목록에 대응하는 값 목록을 반환하며, 키를 찾을 수 없는 경우 NULL을 반환합니다. Any
예시
사용 예시
lowCardinalityIndices
도입된 버전: v18.12.0
LowCardinality 컬럼의 딕셔너리에서 값의 위치를 반환합니다. 위치는 1부터 시작합니다. LowCardinality 컬럼은 파트별 딕셔너리를 사용하므로, 이 함수는 서로 다른 파트에서 동일한 값에 대해 서로 다른 위치를 반환할 수 있습니다.
문법
인수
col— 낮은 카디널리티 컬럼.LowCardinality
반환 값
현재 파트의 딕셔너리에서 값이 위치한 위치입니다. UInt64
예시
사용 예시
lowCardinalityKeys
도입된 버전: v18.12.0
LowCardinality 컬럼의 딕셔너리 값을 반환합니다. 블록 크기가 딕셔너리 크기보다 작거나 큰 경우, 결과는 잘리거나 기본값으로 채워져 확장됩니다. LowCardinality 컬럼은 파트마다 딕셔너리를 별도로 가지므로, 이 함수는 파트마다 서로 다른 딕셔너리 값을 반환할 수 있습니다.
구문
인수
col— 낮은 카디널리티 컬럼.LowCardinality
반환값
딕셔너리의 키를 반환합니다. UInt64
예시
lowCardinalityKeys
materialize
도입된 버전: v1.1.0
상수를 단일 값을 포함하는 전체 컬럼으로 변환합니다. 전체 컬럼과 상수는 메모리에서 서로 다르게 표현됩니다. 함수는 일반(비상수) 인자와 상수 인자에 대해 보통 서로 다른 코드를 실행하지만, 결과는 일반적으로 동일해야 합니다. 이 함수는 이러한 동작을 디버깅하는 데 사용할 수 있습니다.
구문
인수
x— 상수입니다.Any
반환 값
상수 값을 담고 있는 전체 컬럼을 반환합니다. Any
예시
사용 예시
minSampleSizeContinuous
도입된 버전: v23.10.0
두 표본의 연속형 지표 평균을 비교하는 A/B 테스트에 필요한 최소 표본 크기를 계산합니다.
이 글에 설명된 공식을 사용합니다. 처리 집단과 대조 집단의 크기가 동일하다고 가정합니다. 한 집단에 필요한 표본 크기를 반환합니다(즉, 전체 실험에 필요한 표본 크기는 반환값의 두 배입니다). 또한 처리 집단과 대조 집단에서 테스트 지표의 분산이 동일하다고 가정합니다.
Syntax
별칭(Aliases): minSampleSizeContinous
인수(Arguments)
baseline— 메트릭의 기준값.(U)Int*또는Float*sigma— 메트릭의 기준 표준편차.(U)Int*또는Float*mde— 기준값 대비 최소 검출 효과(MDE, Minimum Detectable Effect)의 비율(예: 기준값이 112.25일 때 MDE가 0.03이면, 기대되는 변화는 112.25 ± 112.25*0.03).(U)Int*또는Float*power— 검정에 필요한 통계적 검정력(1 - 제2종 오류(Type II error) 확률).(U)Int*또는Float*alpha— 검정에 필요한 유의수준(제1종 오류(Type I error) 확률).(U)Int*또는Float*
반환 값(Returned value)
3개의 요소 minimum_sample_size, detect_range_lower, detect_range_upper를 가진 이름이 지정된 Tuple을 반환합니다. 각각은 필요한 표본 크기, 반환된 필요한 표본 크기로는 검출할 수 없는 값 구간의 하한값( baseline * (1 - mde) 로 계산), 반환된 필요한 표본 크기로는 검출할 수 없는 값 구간의 상한값( baseline * (1 + mde) 로 계산)을 의미합니다(Float64). Tuple(Float64, Float64, Float64)
예시(Examples)
minSampleSizeContinuous
minSampleSizeConversion
도입된 버전: v22.6.0
두 표본에서 전환율(비율)을 비교하는 A/B 테스트를 위해 필요한 최소 표본 크기를 계산합니다.
이 글에 설명된 공식을 사용합니다. 처리군과 대조군의 크기가 동일하다고 가정합니다. 한 집단에 필요한 표본 크기를 반환합니다(즉, 전체 실험에 필요한 표본 크기는 반환 값의 두 배입니다).
구문
인자
baseline— 기준 전환율.Float*mde— 최소 검출 효과(MDE, Minimum Detectable Effect)를 퍼센트 포인트(percentage points) 단위로 지정합니다(예: 기준 전환율이 0.25이고 MDE가 0.03이면 기대되는 변화는 0.25 ± 0.03).Float*power— 검정에 필요한 통계적 검정력(1 - 제2종 오류 확률).Float*alpha— 검정에 필요한 유의수준(제1종 오류 확률).Float*
반환 값
3개의 요소 minimum_sample_size, detect_range_lower, detect_range_upper를 갖는 이름이 지정된 Tuple을 반환합니다. 각각은 다음을 의미합니다: 필요한 표본 크기, 반환된 필요한 표본 크기로는 검출할 수 없는 값들의 구간 하한(baseline - mde로 계산), 반환된 필요한 표본 크기로는 검출할 수 없는 값들의 구간 상한(baseline + mde로 계산). Tuple(Float64, Float64, Float64)
예시
minSampleSizeConversion
neighbor
도입된 버전: v20.1.0
현재 행에서 지정된 오프셋에 위치한 컬럼의 값을 반환합니다. 이 함수는 데이터 블록의 물리적 순서에 대해 동작하므로, 이 순서가 사용자에게 기대되는 논리적 순서와 일치하지 않을 수 있어 사용이 중단(deprecated)되었으며 오류를 유발하기 쉽습니다. 대신 적절한 윈도우 함수(window function)를 사용하는 것을 고려하십시오.
이 함수는 allow_deprecated_error_prone_window_functions = 1로 설정하여 활성화할 수 있습니다.
구문
인자
column— 원본 컬럼입니다.Anyoffset— 현재 행으로부터의 오프셋입니다. 양수는 이후 행을, 음수는 이전 행을 조회합니다.Integerdefault_value— 선택 사항입니다. 오프셋이 데이터 범위를 벗어날 때 반환할 값입니다. 지정하지 않으면 컬럼 타입의 기본값을 사용합니다.Any
반환 값
지정된 오프셋 위치의 값을 반환하며, 범위를 벗어난 경우 기본값을 반환합니다. Any
예시
사용 예시
기본값 사용 시
normalizeQuery
도입된 버전: v20.8.0
리터럴, 리터럴 시퀀스, 그리고 공백을 포함하거나 숫자가 두 자리보다 많거나 UUID처럼 길이가 최소 36바이트인 복잡한 별칭을 플레이스홀더 ?로 치환합니다.
구문
인수
x— 문자 시퀀스.String
반환 값
지정된 문자 시퀀스를 플레이스홀더를 포함한 형태로 반환합니다. String
예시
사용 예시
normalizeQueryKeepNames
도입된 버전: v21.2.0
리터럴과 연속된 리터럴들을 플레이스홀더 ?로 대체하지만, 공백을 포함하거나 숫자가 2개를 초과해 포함되어 있거나 UUID처럼 최소 36바이트 길이인 복잡한 별칭은 대체하지 않습니다.
이는 복잡한 쿼리 로그를 더 잘 분석하는 데 도움이 됩니다.
구문
인수
x— 문자 시퀀스.String
반환 값
플레이스홀더가 적용된 지정한 문자 시퀀스를 반환합니다. String
예시
사용 예시
normalizedQueryHash
도입된 버전: v20.8.0
유사한 쿼리에 대해 리터럴 값들은 제외하고 동일한 64비트 해시 값을 반환합니다. 쿼리 로그를 분석하는 데 도움이 됩니다.
구문
인수
x— 문자 시퀀스.String
반환 값
64비트 해시 값을 반환합니다. UInt64
예제
사용 예제
normalizedQueryHashKeepNames
도입된 버전: v21.2.0
normalizedQueryHash와 마찬가지로 유사한 쿼리에서 리터럴 값은 제외하고 동일한 64비트 해시 값을 반환하지만, 해시 계산 전에 공백을 포함하거나, 두 자리보다 많은 숫자를 포함하거나, UUID처럼 최소 36바이트 길이인 복잡한 별칭을 플레이스홀더로 대체하지 않습니다.
쿼리 로그를 분석하는 데 유용할 수 있습니다.
구문
인수
x— 문자 시퀀스.String
반환값
64비트 해시값을 반환합니다. UInt64
예제
사용 예제
parseReadableSize
도입 버전: v24.6.0
바이트 크기와 단위(예: B, KiB, KB, MiB, MB 등, 즉 ISO/IEC 80000-13 또는 10진 바이트 단위)가 포함된 문자열이 주어지면, 이 함수는 해당하는 바이트 수를 반환합니다.
함수가 입력값을 파싱하지 못하면 예외를 발생시킵니다.
이 함수의 역연산은 formatReadableSize 및 formatReadableDecimalSize입니다.
구문
인수
x— ISO/IEC 80000-13 또는 10진수 바이트 단위를 사용하는 사람 읽기 용이한 형식의 크기.String
반환 값
가장 가까운 정수로 올림한 바이트 수를 반환합니다. UInt64
예시
사용 예시
parseReadableSizeOrNull
도입된 버전: v24.6.0
바이트 크기를 나타내는 문자열이 주어졌을 때, 단위로 B, KiB, KB, MiB, MB 등(예: ISO/IEC 80000-13 또는 10진수 바이트 단위)을 사용할 수 있으며, 이 함수는 해당하는 바이트 수를 반환합니다.
함수가 입력 값을 해석하지 못하면 NULL을 반환합니다.
이 함수의 역연산은 formatReadableSize와 formatReadableDecimalSize입니다.
구문
인수
x— ISO/IEC 80000-13 또는 10진수 바이트 단위를 사용하는, 사람이 읽기 쉬운 형식의 크기.String
반환 값
가장 가까운 정수로 올림한 바이트 수를 반환하며, 입력을 파싱할 수 없으면 NULL을 반환합니다. Nullable(UInt64)
예시
사용 예시
parseReadableSizeOrZero
도입 버전: v24.6.0
바이트 크기와 단위인 B, KiB, KB, MiB, MB 등(즉, ISO/IEC 80000-13 또는 10진수 바이트 단위)이 포함된 문자열이 주어지면, 이 함수는 해당하는 바이트 수를 반환합니다.
입력 값을 파싱하지 못하면 0을 반환합니다.
이 함수의 역연산은 formatReadableSize 및 formatReadableDecimalSize입니다.
구문
인수
x— ISO/IEC 80000-13 또는 10진수 바이트 단위를 사용하는 사람이 읽기 쉬운 크기입니다.String
반환 값
가장 가까운 정수로 올림한 바이트 수를 반환하며, 입력을 파싱할 수 없으면 0을 반환합니다. UInt64
예시
사용 예시
parseTimeDelta
도입 버전: v22.7.0
시간 단위를 나타내는 문자열이 뒤따르는 숫자 나열을 파싱합니다.
시간 차이 문자열은 다음과 같은 시간 단위 표기를 사용합니다:
years,year,yr,ymonths,month,moweeks,week,wdays,day,dhours,hour,hr,hminutes,minute,min,mseconds,second,sec,smilliseconds,millisecond,millisec,msmicroseconds,microsecond,microsec,μs,µs,usnanoseconds,nanosecond,nanosec,ns
여러 시간 단위를 구분자(공백, ;, -, +, ,, :)로 결합하여 사용할 수 있습니다.
년(year)과 월(month)의 길이는 근사값으로 취급됩니다. 1년은 365일, 1개월은 30.5일로 계산합니다.
구문
인수
timestr— 숫자들의 시퀀스로, 뒤에 시간 단위를 나타내는 문자열이 옵니다.String
반환 값
초 단위의 값입니다. Float64
예시
사용 예시
복합 시간 단위
partitionId
도입된 버전: v21.4.0
파티션 ID를 계산합니다.
이 함수는 속도가 느리므로 많은 수의 행에 대해서는 호출하지 않는 것이 좋습니다.
구문
별칭: partitionID
인수
column1, column2, ...— 파티션 ID를 반환할 컬럼입니다.
반환 값
행이 속한 파티션 ID를 반환합니다. String
예시
사용 예시
queryID
도입 버전: v21.9.0
현재 쿼리의 ID를 반환합니다.
쿼리의 다른 매개변수는 system.query_log 테이블의 query_id 필드에서 추출할 수 있습니다.
initialQueryID 함수와 달리 queryID는 세그먼트마다 서로 다른 결과를 반환할 수 있습니다.
구문
별칭: query_id
인수
- 없음
반환 값
현재 쿼리의 ID를 반환합니다. String
예제
사용 예
revision
도입 버전: v22.7.0
현재 ClickHouse 서버의 리비전을 반환합니다.
구문
인수
- 없음.
반환값
현재 ClickHouse 서버 리비전을 반환합니다. UInt32
예시
사용 예시
rowNumberInAllBlocks
도입된 버전: v1.1.0
처리되는 각 행에 대해 고유한 행 번호를 반환합니다.
구문
인수
- 없음.
반환 값
데이터 블록에서 0부터 시작하는 행의 순서를 반환합니다. UInt64
예시
사용 예시
rowNumberInBlock
도입된 버전: v1.1.0
rowNumberInBlock가 처리하는 각 블록에 대해 현재 행의 번호를 반환합니다.
반환되는 번호는 각 블록에서 0부터 시작합니다.
구문
인수
- 없음.
반환값
데이터 블록에서 0부터 시작하는 행 번호를 반환합니다. UInt64
예시
사용 예시
runningAccumulate
도입: v1.1.0
데이터 블록의 각 행에 대해 집계 함수의 상태를 누적합니다.
각 새로운 데이터 블록마다 상태가 초기화됩니다.
이와 같은 오류가 발생하기 쉬운 동작 때문에 이 함수는 사용이 중단되었으며, 대신 윈도우 함수를 사용할 것을 권장합니다.
설정 allow_deprecated_error_prone_window_functions를 사용하면 이 함수를 계속 사용할 수 있습니다.
구문
인수
agg_state— 집계 함수의 상태.AggregateFunctiongrouping— 선택 사항. 그룹화 키.grouping값이 변경되면 함수의 상태가 초기화됩니다. 같음 연산자(=)가 정의된, 지원되는 임의의 데이터 타입을 사용할 수 있습니다.Any
반환 값
각 행마다 누적된 결과를 반환합니다. Any
예시
initializeAggregation 사용 예시
runningConcurrency
도입 버전: v21.3.0
동시에 발생하는 이벤트 수를 계산합니다. 각 이벤트는 시작 시간과 종료 시간을 가집니다. 시작 시간은 이벤트에 포함되지만, 종료 시간은 포함되지 않습니다. 시작 시간과 종료 시간을 가진 컬럼은 동일한 데이터 타입이어야 합니다. 이 함수는 각 이벤트 시작 시간에 대해 활성(동시) 이벤트의 총 개수를 계산합니다.
이벤트는 시작 시간 기준으로 오름차순 정렬되어 있어야 합니다. 이 요구 사항을 위반하면 함수가 예외를 발생시킵니다. 각 데이터 블록은 개별적으로 처리됩니다. 서로 다른 데이터 블록의 이벤트가 겹치는 경우 올바르게 처리되지 않을 수 있습니다.
대신 window functions를 사용할 것을 권장합니다.
구문
인수
start— 이벤트 시작 시각을 나타내는 컬럼입니다.Date또는DateTime또는DateTime64end— 이벤트 종료 시각을 나타내는 컬럼입니다.Date또는DateTime또는DateTime64
반환 값
각 이벤트 시작 시점에 동시에 진행 중인 이벤트 수를 반환합니다. UInt32
예시
사용 예시
runningDifference
도입 버전: v1.1.0
데이터 블록에서 연속된 두 행의 값 차이를 계산합니다.
첫 번째 행에 대해서는 0을 반환하고, 이후 행에 대해서는 이전 행과의 차이를 반환합니다.
현재 처리 중인 데이터 블록 내부에서만 차이를 반환합니다. 이러한 오류가 발생하기 쉬운 동작 때문에 이 함수는 사용 중단되었습니다. 대신 window functions을(를) 사용할 것을 권장합니다.
이 함수를 사용하려면 설정 allow_deprecated_error_prone_window_functions을(를) 활성화하면 됩니다.
함수의 결과는 대상이 되는 데이터 블록과 블록 내 데이터의 순서에 따라 달라집니다.
runningDifference()를 계산하는 동안의 행 순서는 사용자에게 반환되는 행 순서와 다를 수 있습니다.
이를 방지하려면 ORDER BY를 사용하는 서브쿼리를 만든 다음, 서브쿼리 바깥에서 이 함수를 호출하면 됩니다.
블록 크기가 결과에 영향을 준다는 점에 유의하십시오.
runningDifference의 내부 상태는 새 블록마다 초기화됩니다.
Syntax
인수
x— running difference를 계산할 컬럼.Any
반환 값
연속된 값들 사이의 차이를 반환하며, 첫 번째 행에는 0을 반환합니다.
예시
사용 예시
블록 크기가 미치는 영향 예시
runningDifferenceStartingWithFirstValue
도입: v1.1.0
데이터 블록에서 연속된 행 값 간의 차이를 계산합니다. 단, runningDifference와는 달리 첫 번째 행에 대해서는 0이 아니라 실제 값을 반환합니다.
현재 처리 중인 데이터 블록에서만 차이를 반환합니다. 이로 인해 오류가 발생하기 쉬운 동작이므로, 이 함수는 더 이상 사용이 권장되지 않습니다. 대신 window functions를 사용할 것을 권장합니다.
이 함수를 사용하려면 setting allow_deprecated_error_prone_window_functions을(를) 사용할 수 있습니다.
구문
인수
x— 누적 차이(running difference)를 계산할 컬럼.Any
반환 값
연속된 값들 사이의 차이를 반환하며, 첫 번째 행에는 첫 번째 행의 값을 그대로 반환합니다. Any
예시
사용 예시
serverUUID
도입된 버전: v20.1.0
서버가 처음 시작될 때 생성되는 무작위이면서 고유한 UUID (v4)를 반환합니다. 이 UUID는 영구적으로 저장되므로, 두 번째, 세 번째 등 이후 서버 시작 시에도 동일한 UUID를 반환합니다.
구문
인수
- 없음.
반환 값
서버의 임의 UUID를 반환합니다. UUID
예시
사용 예시
shardCount
도입된 버전: v21.9.0
분산 쿼리에 대한 총 세그먼트 수를 반환합니다.
쿼리가 분산되지 않은 경우 상수 값 0을 반환합니다.
구문
인수
- 없습니다.
반환값
세그먼트의 총 개수 또는 0을 반환합니다. UInt32
예시
사용 예시
shardNum
도입된 버전: v21.9.0
분산 쿼리에서 데이터의 일부를 처리하는 세그먼트의 인덱스를 반환합니다.
인덱스는 1부터 시작합니다.
쿼리가 분산되지 않은 경우 상수 값 0을 반환합니다.
구문
인수
- 없음
반환 값
세그먼트 인덱스 또는 상수 0을 반환합니다. UInt32
예제
사용 예제
showCertificate
도입: v22.6.0
현재 서버에 SSL(Secure Sockets Layer) 인증서가 설정되어 있는 경우 해당 인증서 정보를 표시합니다. 연결을 검증하도록 ClickHouse에서 OpenSSL 인증서를 사용하도록 구성하는 방법에 대한 자세한 내용은 Configuring TLS를 참조하십시오.
구문
인수
- 없음.
반환 값
구성된 SSL 인증서와 관련된 key-value 쌍의 맵을 반환합니다. Map(String, String)
예시
사용 예시
sleep
도입 버전: v1.1.0
지정된 초 동안 쿼리 실행을 일시 중지합니다. 이 함수는 주로 테스트 및 디버깅 용도로 사용됩니다.
sleep() 함수는 쿼리 성능과 시스템 응답성에 부정적인 영향을 줄 수 있으므로, 일반적으로 운영 환경에서는 사용하지 않는 것이 좋습니다.
그러나 다음과 같은 시나리오에서는 유용할 수 있습니다:
- 테스트: ClickHouse를 테스트하거나 벤치마킹할 때, 특정 조건에서 시스템이 어떻게 동작하는지 관찰하기 위해 지연을 시뮬레이션하거나 일시 중지를 도입해야 할 수 있습니다.
- 디버깅: 시스템 상태나 쿼리 실행을 특정 시점에서 살펴볼 필요가 있는 경우,
sleep()을 사용해 일시 중지를 도입하여 관련 정보를 검사하거나 수집할 수 있습니다. - 시뮬레이션: 네트워크 지연이나 외부 시스템 의존성과 같이 실제 환경에서 발생하는 지연이나 일시 중지 상황을 시뮬레이션해야 하는 경우가 있을 수 있습니다.
sleep() 함수는 ClickHouse 시스템의 전체 성능과 응답성에 영향을 줄 수 있으므로, 반드시 필요한 경우에만 신중하게 사용해야 합니다.
보안상의 이유로, 이 함수는 기본 사용자 프로필(default user profile, allow_sleep이 활성화된 경우)에서만 실행할 수 있습니다.
구문
인수
seconds— 쿼리 실행을 일시 중지할 초 단위 시간(최대 3초)입니다. 소수 초를 지정하기 위해 부동 소수점 값으로 설정할 수 있습니다.const UInt*또는const Float*
반환 값
0을 반환합니다. UInt8
예시
사용 예시
sleepEachRow
도입된 버전: v1.1.0
결과 집합의 각 행에 대해 지정된 초만큼 쿼리 실행을 일시 중지합니다.
sleepEachRow() FUNCTION은 주로 sleep() FUNCTION과 마찬가지로 테스트 및 디버깅 목적에 사용됩니다.
각 행을 처리할 때 지연을 시뮬레이션하거나 일시 정지를 도입할 수 있으며, 다음과 같은 상황에서 유용합니다.
- 테스트: 특정 조건에서 ClickHouse의 성능을 테스트하거나 벤치마킹할 때, 처리되는 각 행에 대해 지연을 시뮬레이션하거나 일시 정지를 도입하기 위해
sleepEachRow()를 사용할 수 있습니다. - 디버깅: 처리되는 각 행에 대해 시스템 상태나 쿼리 실행 상태를 점검해야 하는 경우,
sleepEachRow()로 일시 정지를 도입하여 관련 정보를 조사하거나 수집할 수 있습니다. - 시뮬레이션: 외부 시스템이나 네트워크 지연을 처리하는 경우처럼, 처리되는 각 행마다 지연이나 일시 정지가 발생하는 실제 시나리오를 시뮬레이션해야 하는 경우에 사용할 수 있습니다.
sleep() FUNCTION과 마찬가지로, sleepEachRow()는 특히 결과 집합이 큰 경우 전체 ClickHouse 시스템의 성능과 응답성에 상당한 영향을 줄 수 있으므로, 반드시 필요한 경우에만 신중하게 사용해야 합니다.
구문
인수
seconds— 결과 집합의 각 행에 대해 쿼리 실행을 일시 중지할 시간(초 단위)로, 최대 3초까지 지정합니다. 소수 초를 지정하기 위해 부동 소수점 값일 수 있습니다.const UInt*또는const Float*
반환 값
각 행에 대해 0을 반환합니다. UInt8
예시
사용 예시
structureToCapnProtoSchema
도입 버전: v23.8.0
ClickHouse 테이블 구조를 CapnProto 형식의 스키마로 변환하는 함수입니다.
구문
인수
- 없음
반환값
예제
random
structureToProtobufSchema
도입 버전: v23.8.0
ClickHouse 테이블 구조를 Protobuf 형식의 스키마로 변환합니다.
이 FUNCTION은 ClickHouse 테이블 구조 정의를 받아 Protocol Buffers(Protobuf) proto3 구문의 스키마 정의로 변환합니다. 이는 데이터 교환을 위해 ClickHouse 테이블 구조와 일치하는 Protobuf 스키마를 생성할 때 유용합니다.
구문
인수
structure— 문자열 형태의 ClickHouse 테이블 구조 정의(예: 'column1 Type1, column2 Type2').Stringmessage_name— 생성된 스키마에서 Protobuf 메시지 타입의 이름입니다.String
반환 값
입력 ClickHouse 구조에 대응하는 proto3 문법의 Protobuf 스키마 정의를 반환합니다. String
예시
ClickHouse 구조를 Protobuf 스키마로 변환
tcpPort
도입된 버전: v20.12.0
서버가 수신 대기하는 native interface TCP 포트 번호를 반환합니다. 분산 테이블 컨텍스트에서 실행되는 경우, 이 함수는 각 세그먼트에 해당하는 값을 갖는 일반 컬럼을 생성합니다. 그 외의 경우에는 상수 값을 반환합니다.
구문
매개변수
- 없음.
반환 값
TCP 포트 번호를 반환합니다. UInt16
예제
사용 예제
throwIf
도입된 버전: v1.1.0
인자 x가 true인 경우 예외를 발생시킵니다.
error_code 인자를 사용하려면 설정 매개변수 allow_custom_error_code_in_throw가 활성화되어 있어야 합니다.
구문
인수
x— 검사할 조건.Anymessage— 선택적입니다. 사용자 정의 오류 메시지.const Stringerror_code— 선택적입니다. 사용자 정의 오류 코드.const Int8/16/32
반환 값
조건이 거짓이면 0을 반환하고, 조건이 참이면 예외를 발생시킵니다. UInt8
예제
사용 예제
toColumnTypeName
도입된 버전: v1.1.0
지정된 값의 데이터 타입에 대한 내부 이름을 반환합니다.
toTypeName 함수와는 달리, 반환되는 데이터 타입에는 Const, LowCardinality와 같은 내부 래퍼 컬럼이 포함될 수 있습니다.
문법
인수(Arguments)
value— 내부 데이터 타입을 확인할 값.Any
반환 값
값을 표현하는 데 사용되는 내부 데이터 타입을 반환합니다. String
예시(Examples)
사용 예시(Usage example)
toTypeName
도입 버전: v1.1.0
전달된 인수의 타입 이름을 반환합니다.
NULL이 전달되면 함수는 ClickHouse의 내부 NULL 표현에 해당하는 타입 Nullable(Nothing)을 반환합니다.
구문
인수
x— 임의의 타입 값.Any
반환값
입력 값의 데이터 타입 이름을 반환합니다. String
예시
사용 예시
transactionID
도입 버전: v22.6.0
트랜잭션의 ID를 반환합니다.
이 함수는 실험적 기능 세트의 일부입니다. 실험적 트랜잭션 지원을 활성화하려면 다음 설정을 구성에 추가하십시오:
자세한 내용은 Transactional (ACID) support 페이지를 참고하십시오.
구문
인수(Arguments)
- 없음.
반환 값(Returned value)
start_csn, local_tid, host_id로 구성된 튜플을 반환합니다.
start_csn: 이 트랜잭션이 시작될 때까지 관측된 가장 최신 커밋 타임스탬프에 해당하는 전역 일련 번호입니다.local_tid: 특정start_csn내에서 이 호스트가 시작한 각 트랜잭션에 대해 고유한 로컬 일련 번호입니다.host_id: 이 트랜잭션을 시작한 호스트의 UUID입니다.Tuple(UInt64, UInt64, UUID)
예시(Examples)
사용 예시(Usage example)
transactionLatestSnapshot
도입된 버전: v22.6.0
읽기 가능한 트랜잭션의 최신 스냅샷(Commit Sequence Number)을 반환합니다.
이 함수는 실험적 기능 모음의 일부입니다. 구성에 다음 설정을 추가하여 실험적 트랜잭션 지원을 활성화하십시오.
자세한 내용은 Transactional (ACID) support 페이지를 참조하십시오.
구문
인수
- 없음.
반환값
트랜잭션의 최신 스냅샷(CSN)을 반환합니다. UInt64
예제
사용 예제
transactionOldestSnapshot
도입 버전: v22.6.0
실행 중인 트랜잭션 중 일부에서 볼 수 있는 가장 오래된 스냅샷(Commit Sequence Number)을 반환합니다.
이 함수는 실험적 기능 집합의 일부입니다. 설정에 다음 설정을 추가하여 실험적 트랜잭션 지원을 활성화하십시오:
자세한 내용은 Transactional (ACID) support 페이지를 참조하십시오.
구문
인수
- 없음.
반환값
트랜잭션의 가장 오래된 스냅샷(CSN)을 반환합니다. UInt64
예제
사용 예제
transform
도입된 버전: v1.1.0
일부 요소를 다른 요소로 매핑하는 방식이 명시적으로 정의된 매핑에 따라 값을 변환합니다.
이 함수에는 두 가지 형태가 있습니다.
transform(x, array_from, array_to, default)- 매핑 배열을 사용하여x를 변환하며, 일치하지 않는 요소에 대해서는 기본값을 사용합니다.transform(x, array_from, array_to)- 동일한 변환을 수행하지만, 일치하는 항목이 없으면 원래x를 반환합니다.
함수는 array_from에서 x를 찾아 동일한 인덱스에 있는 array_to의 대응 요소를 반환합니다.
x가 array_from에서 발견되지 않으면 default 값(4-매개변수 버전) 또는 원래 x(3-매개변수 버전)를 반환합니다.
array_from에 여러 개의 일치하는 요소가 있는 경우, 첫 번째로 일치한 요소에 대응하는 값을 반환합니다.
요구 사항:
array_from과array_to는 동일한 개수의 요소를 가져야 합니다.- 4-매개변수 버전:
transform(T, Array(T), Array(U), U) -> U여기서T와U는 서로 호환 가능한 서로 다른 타입일 수 있습니다. - 3-매개변수 버전:
transform(T, Array(T), Array(T)) -> T여기서 모든 타입은 동일해야 합니다.
Syntax
인자
x— 변환할 값입니다.(U)Int*또는Decimal또는Float*또는String또는Date또는DateTimearray_from— 일치하는 값을 검색할 상수 배열입니다.Array((U)Int*)또는Array(Decimal)또는Array(Float*)또는Array(String)또는Array(Date)또는Array(DateTime)array_to—array_from에서 일치하는 항목에 대해 반환할 값을 담은 상수 배열입니다.Array((U)Int*)또는Array(Decimal)또는Array(Float*)또는Array(String)또는Array(Date)또는Array(DateTime)default— 선택 사항입니다.x가array_from에 없을 때 반환할 값입니다. 생략하면x를 변경하지 않고 그대로 반환합니다.(U)Int*또는Decimal또는Float*또는String또는Date또는DateTime
반환 값
x가 array_from의 요소와 일치하면 array_to에서 해당 값을 반환하고, 그렇지 않으면 default(제공된 경우)를 반환하거나, default가 제공되지 않은 경우 x를 그대로 반환합니다. Any
예시
transform(T, Array(T), Array(U), U) -> U
transform(T, Array(T), Array(T)) -> T
uniqThetaIntersect
도입 버전: v22.9.0
두 uniqThetaSketch 객체 사이의 교집합(집합 연산 ∩)을 계산하며, 결과는 새로운 uniqThetaSketch입니다.
구문
인수
uniqThetaSketch— uniqThetaSketch 객체입니다.Tuple또는Array또는Date또는DateTime또는String또는(U)Int*또는Float*또는Decimal
반환 값
교집합 결과를 포함하는 새 uniqThetaSketch입니다. UInt64
예시
사용 예시
uniqThetaNot
도입 버전: v22.9.0
두 개의 uniqThetaSketch 객체에 대해 a_not_b 계산(집합 연산인 차집합)을 수행하며, 결과는 새로운 uniqThetaSketch입니다.
구문
인수
uniqThetaSketch— uniqThetaSketch 객체.Tuple또는Array또는Date또는DateTime또는String또는(U)Int*또는Float*또는Decimal
반환 값
a_not_b 결과를 포함하는 새로운 uniqThetaSketch를 반환합니다. UInt64
예시
사용 예시
uniqThetaUnion
도입 버전: v22.9.0
두 개의 uniqThetaSketch 객체에 대해 합집합 연산(집합 연산 ∪)을 수행하며, 결과는 새로운 uniqThetaSketch 객체입니다.
구문
인수
uniqThetaSketch— uniqThetaSketch 객체입니다.Tuple또는Array또는Date또는DateTime또는String또는(U)Int*또는Float*또는Decimal
반환값
합집합 결과를 포함하는 새로운 uniqThetaSketch를 반환합니다. UInt64
예제
사용 예
uptime
도입 버전: v1.1.0
서버 업타임(가동 시간)을 초 단위로 반환합니다. 분산 테이블에서 실행되는 경우, 이 함수는 각 세그먼트에 해당하는 값을 가진 일반 컬럼을 생성합니다. 그렇지 않으면 상수 값을 생성합니다.
구문
인수
- 없음.
반환 값
서버 가동 시간을 초 단위로 반환합니다. UInt32
예시
사용 예제
variantElement
도입된 버전: v25.2.0
Variant 컬럼에서 지정된 타입의 컬럼을 추출합니다.
구문
인수
variant— Variant 컬럼.Varianttype_name— 추출할 variant 타입의 이름.Stringdefault_value— variant에 지정한 타입의 variant가 없을 때 사용될 기본값. 모든 데이터 타입을 사용할 수 있습니다. 선택 사항입니다.Any
반환 값
Variant 컬럼에서 지정한 variant 타입의 값을 추출한 컬럼을 반환합니다. Any
예시
사용 예시
variantType
도입된 버전: v24.2.0
Variant 컬럼의 각 행에 대해 variant 타입 이름을 반환합니다. 행에 NULL이 포함되어 있으면 해당 행에 대해서는 「None」을 반환합니다.
구문
인수
variant— Variant 컬럼.Variant
반환 값
각 행에 대해 Variant 타입 이름이 포함된 Enum 컬럼을 반환합니다. Enum
예시
사용 예시
version
도입된 버전: v1.1.0
현재 ClickHouse의 버전을 major_version.minor_version.patch_version.number_of_commits_since_the_previous_stable_release 형식의 문자열로 반환합니다.
분산 테이블의 컨텍스트에서 실행되는 경우, 이 함수는 각 세그먼트에 해당하는 값을 가진 일반 컬럼을 생성합니다.
그렇지 않으면 상수 값을 반환합니다.
구문
인수
- 없음.
반환값
ClickHouse의 현재 버전을 반환합니다. String
예시
사용 예시
visibleWidth
도입 버전: v1.1.0
텍스트 형식(탭으로 구분)으로 값을 콘솔에 출력할 때의 대략적인 너비를 계산합니다.
이 함수는 시스템에서 Pretty 포맷을 구현하는 데 사용됩니다.
Pretty 포맷에서는 NULL이 NULL에 해당하는 문자열로 출력됩니다.
구문
인수
x— 임의의 데이터 타입 값.Any
반환 값
값을 텍스트 형식으로 표시했을 때의 대략적인 너비를 반환합니다. UInt64
예시
NULL의 표시 너비 계산
zookeeperSessionUptime
도입 버전: v21.11.0
현재 ZooKeeper 세션의 가동 시간을 초 단위로 반환합니다.
구문
인수
- 없음.
반환 값
현재 ZooKeeper 세션의 가동 시간을 초 단위로 반환합니다. UInt32
예시
사용 예시