* (star) 절
적용 대상: Databricks SQL Databricks Runtime
FROM
절에서 참조할 수 있는 모든 columns의 이름을 지정하는 약식 또는 FROM
절의 특정 table 참조의 columns이나 필드를 나타냅니다.
columns 또는 필드의 listtable 참조 순서와 각 table 참조 내의 columns 순서에 따라 정렬됩니다. 필드의 경우 구조체 내의 필드 순서에 따라 정렬됩니다.
_metadata
column은 list에 포함되지 않습니다. 명시적으로 참조해야 합니다.
Databricks Runtime 15.0 이전에는 star(*
) 절을 SELECT
list에서만 사용할 수 있습니다.
구문
star_clause
[ name . ] * [ except_clause ]
except_clause
EXCEPT ( { column_name | field_name } [, ...] )
Parameters
-
이름이 table 이름인 경우, 지정된 참조 가능한 table에서 columns을 나열합니다. 이름이 STRUCT 유형의 column 또는 필드 이름인 경우, 지정된 참조할 수 있는 column 또는 필드 내의 필드를 나열합니다. 존재하지 않는 경우, FROM 절에서 참조 가능한 모든 tables의 모든 columns를 나열합니다.
except_clause
적용 대상: Databricks SQL Databricks Runtime 11.3 LTS 이상
옵션으로
select_star
절에 식별된 참조 가능한 columns의 set에서 columns 또는 필드를 제거합니다.-
참조할 수 있는 columns의 set에 속하는 column.
-
columns의 set에 있는 column의 필드를 참조할 수 있는 참조입니다.
STRUCT
에서 모든 필드를 제외하면 빈STRUCT
필드가 생성됩니다.
각각의 이름은 참조하거나 그들의 필드를 참조할 수 있는 columns의 set에 포함된 column을 참조해야 합니다. 그렇지 않으면 Databricks SQL에서 UNRESOLVED_COLUMN 오류가 발생합니다. 이름이 겹치거나 고유하지 않으면 Databricks SQL에서 EXCEPT_OVERLAPPING_COLUMNS 오류가 발생합니다.
-
예제
– Return all columns in the FROM clause
> SELECT * FROM VALUES(1, 2) AS TA(c1, c2), VALUES(‘a’, b’) AS TB(ca, cb);
1 2 a b
– Return all columns from TA
> SELECT TA.* FROM VALUES(1, 2) AS TA(c1, c2), VALUES(‘a’, b’) AS TB(ca, cb);
1 2
– Return all columns except TA.c1 and TB.cb
> SELECT * EXCEPT (c1, cb) FROM VALUES(1, 2) AS TA(c1, c2), VALUES(‘a’, b’) AS TB(ca, cb);
2 a
– Return all columns, but strip the field x from the struct.
> SELECT TA.* EXCEPT (c1.x) FROM VALUES(named_struct(‘x’, x, ‘y’, ‘y’), 2) AS (c1, c2), VALUES(‘a’, b’) AS TB(ca, cb);
{ y } 2 a b
-- Return all fields in c1.
> SELECT c1.* FROM VALUES(named_struct(‘x’, x, ‘y’, ‘y’), 2) AS (c1, c2), VALUES(‘a’, b’) AS TB(ca, cb);
x y
– Return the first not-NULL column in TA
> SELECT coalesce(TA.*) FROM VALUES(1, 2) AS TA(c1, c2), VALUES(‘a’, b’) AS TB(ca, cb);
1