Edit on GitHub

sqlglot expressions - array, map, struct, and table-valued functions.

  1"""sqlglot expressions - array, map, struct, and table-valued functions."""
  2
  3from __future__ import annotations
  4
  5
  6from sqlglot.expressions.core import (
  7    Expression,
  8    Expr,
  9    Func,
 10    Binary,
 11    to_identifier,
 12)
 13from sqlglot.helper import trait
 14from sqlglot.expressions.query import UDTF
 15
 16
 17# Array creation / construction
 18
 19
 20class Array(Expression, Func):
 21    arg_types = {
 22        "expressions": False,
 23        "bracket_notation": False,
 24        "struct_name_inheritance": False,
 25    }
 26    is_var_len_args = True
 27
 28
 29class ArrayConstructCompact(Expression, Func):
 30    arg_types = {"expressions": False}
 31    is_var_len_args = True
 32
 33
 34class List(Expression, Func):
 35    arg_types = {"expressions": False}
 36    is_var_len_args = True
 37
 38
 39class ToArray(Expression, Func):
 40    pass
 41
 42
 43# Array manipulation
 44
 45
 46class ArrayAppend(Expression, Func):
 47    arg_types = {"this": True, "expression": True, "null_propagation": False}
 48
 49
 50class ArrayCompact(Expression, Func):
 51    pass
 52
 53
 54class ArrayConcat(Expression, Func):
 55    _sql_names = ["ARRAY_CONCAT", "ARRAY_CAT"]
 56    arg_types = {"this": True, "expressions": False, "null_propagation": False}
 57    is_var_len_args = True
 58
 59
 60class ArrayFilter(Expression, Func):
 61    arg_types = {"this": True, "expression": True}
 62    _sql_names = ["FILTER", "ARRAY_FILTER"]
 63
 64
 65class ArrayInsert(Expression, Func):
 66    arg_types = {"this": True, "position": True, "expression": True, "offset": False}
 67
 68
 69class ArrayPrepend(Expression, Func):
 70    arg_types = {"this": True, "expression": True, "null_propagation": False}
 71
 72
 73class ArrayRemove(Expression, Func):
 74    arg_types = {"this": True, "expression": True, "null_propagation": False}
 75
 76
 77class ArrayRemoveAt(Expression, Func):
 78    arg_types = {"this": True, "position": True}
 79
 80
 81class ArrayReverse(Expression, Func):
 82    pass
 83
 84
 85class ArraySlice(Expression, Func):
 86    arg_types = {"this": True, "start": True, "end": False, "step": False, "zero_based": False}
 87
 88
 89class ArraySort(Expression, Func):
 90    arg_types = {"this": True, "expression": False}
 91
 92
 93class SortArray(Expression, Func):
 94    arg_types = {"this": True, "asc": False, "nulls_first": False}
 95
 96
 97# Array predicates / search
 98
 99
100class ArrayAll(Expression, Func):
101    arg_types = {"this": True, "expression": True}
102
103
104class ArrayAny(Expression, Func):
105    arg_types = {"this": True, "expression": True}
106
107
108class ArrayContains(Expression, Binary, Func):
109    arg_types = {"this": True, "expression": True, "ensure_variant": False, "check_null": False}
110    _sql_names = ["ARRAY_CONTAINS", "ARRAY_HAS"]
111
112
113class ArrayContainsAll(Expression, Binary, Func):
114    _sql_names = ["ARRAY_CONTAINS_ALL", "ARRAY_HAS_ALL"]
115
116
117class ArrayExcept(Expression, Func):
118    arg_types = {"this": True, "expression": True, "is_multiset": False}
119
120
121class ArrayIntersect(Expression, Func):
122    arg_types = {"expressions": True, "is_multiset": False}
123    is_var_len_args = True
124    _sql_names = ["ARRAY_INTERSECT", "ARRAY_INTERSECTION"]
125
126
127class ArrayOverlaps(Expression, Binary, Func):
128    arg_types = {"this": True, "expression": True, "null_safe": False}
129
130
131class ArrayPosition(Expression, Binary, Func):
132    arg_types = {"this": True, "expression": True, "zero_based": False}
133
134
135# Array properties
136
137
138class ArrayDistinct(Expression, Func):
139    arg_types = {"this": True, "check_null": False}
140
141
142class ArrayFirst(Expression, Func):
143    arg_types = {"this": True, "expression": False}
144
145
146class ArrayLast(Expression, Func):
147    pass
148
149
150class ArrayMax(Expression, Func):
151    pass
152
153
154class ArrayMin(Expression, Func):
155    pass
156
157
158class ArraySize(Expression, Func):
159    arg_types = {"this": True, "expression": False}
160    _sql_names = ["ARRAY_SIZE", "ARRAY_LENGTH"]
161
162
163class ArraySum(Expression, Func):
164    arg_types = {"this": True, "expression": False}
165
166
167# Array conversion / utility
168
169
170class ArraysZip(Expression, Func):
171    arg_types = {"expressions": False}
172    is_var_len_args = True
173
174
175class ArrayToString(Expression, Func):
176    arg_types = {
177        "this": True,
178        "expression": True,
179        "null": False,
180        "null_is_empty": False,
181        "null_delim_is_null": False,
182    }
183    _sql_names = ["ARRAY_TO_STRING", "ARRAY_JOIN"]
184
185
186class Flatten(Expression, Func):
187    pass
188
189
190class StringToArray(Expression, Func):
191    arg_types = {"this": True, "expression": False, "null": False}
192    _sql_names = ["STRING_TO_ARRAY", "SPLIT_BY_STRING"]
193
194
195class StrtokToArray(Expression, Func):
196    arg_types = {"this": True, "expression": False}
197
198
199# Higher-order / lambda
200
201
202class Apply(Expression, Func):
203    arg_types = {"this": True, "expression": True}
204
205
206class Reduce(Expression, Func):
207    arg_types = {"this": True, "initial": True, "merge": True, "finish": False}
208
209
210class Transform(Expression, Func):
211    arg_types = {"this": True, "expression": True}
212
213
214# Table-valued / UDTF
215
216
217class GenerateSeries(Expression, Func):
218    arg_types = {"start": True, "end": True, "step": False, "is_end_exclusive": False}
219
220
221class ExplodingGenerateSeries(GenerateSeries):
222    pass
223
224
225class Generator(Expression, Func, UDTF):
226    arg_types = {"rowcount": False, "timelimit": False}
227
228
229class Explode(Expression, Func, UDTF):
230    arg_types = {"this": True, "expressions": False}
231    is_var_len_args = True
232
233
234class Inline(Expression, Func):
235    pass
236
237
238@trait
239class ExplodeOuter(Expr):
240    pass
241
242
243class _ExplodeOuter(Explode, ExplodeOuter):
244    _sql_names = ["EXPLODE_OUTER"]
245
246
247class Posexplode(Explode):
248    pass
249
250
251class PosexplodeOuter(Posexplode, ExplodeOuter):
252    pass
253
254
255class PositionalColumn(Expression):
256    pass
257
258
259class Unnest(Expression, Func, UDTF):
260    arg_types = {
261        "expressions": True,
262        "alias": False,
263        "offset": False,
264        "explode_array": False,
265    }
266
267    @property
268    def selects(self) -> list[Expr]:
269        columns = super().selects
270        offset = self.args.get("offset")
271        if offset:
272            columns = columns + [to_identifier("offset") if offset is True else offset]
273        return columns
274
275
276# Map
277
278
279class Map(Expression, Func):
280    arg_types = {"keys": False, "values": False}
281
282    @property
283    def keys(self) -> list[Expr]:
284        keys = self.args.get("keys")
285        return keys.expressions if keys else []
286
287    @property
288    def values(self) -> list[Expr]:
289        values = self.args.get("values")
290        return values.expressions if values else []
291
292
293class MapCat(Expression, Func):
294    arg_types = {"this": True, "expression": True}
295
296
297class MapContainsKey(Expression, Func):
298    arg_types = {"this": True, "key": True}
299
300
301class MapDelete(Expression, Func):
302    arg_types = {"this": True, "expressions": True}
303    is_var_len_args = True
304
305
306class MapFromEntries(Expression, Func):
307    pass
308
309
310class MapInsert(Expression, Func):
311    arg_types = {"this": True, "key": False, "value": True, "update_flag": False}
312
313
314class MapKeys(Expression, Func):
315    pass
316
317
318class MapPick(Expression, Func):
319    arg_types = {"this": True, "expressions": True}
320    is_var_len_args = True
321
322
323class MapSize(Expression, Func):
324    pass
325
326
327class StarMap(Expression, Func):
328    pass
329
330
331class ToMap(Expression, Func):
332    pass
333
334
335class VarMap(Expression, Func):
336    arg_types = {"keys": True, "values": True}
337    is_var_len_args = True
338
339    @property
340    def keys(self) -> list[Expr]:
341        return self.args["keys"].expressions
342
343    @property
344    def values(self) -> list[Expr]:
345        return self.args["values"].expressions
346
347
348# Struct
349
350
351class Struct(Expression, Func):
352    arg_types = {"expressions": False}
353    is_var_len_args = True
354
355
356class StructExtract(Expression, Func):
357    arg_types = {"this": True, "expression": True}
358
359
360# Geospatial
361
362
363class StDistance(Expression, Func):
364    arg_types = {"this": True, "expression": True, "use_spheroid": False}
365
366
367class StPoint(Expression, Func):
368    arg_types = {"this": True, "expression": True, "z": False, "m": False}
369    _sql_names = ["ST_POINT", "ST_MAKEPOINT"]
21class Array(Expression, Func):
22    arg_types = {
23        "expressions": False,
24        "bracket_notation": False,
25        "struct_name_inheritance": False,
26    }
27    is_var_len_args = True
arg_types = {'expressions': False, 'bracket_notation': False, 'struct_name_inheritance': False}
is_var_len_args = True
key: ClassVar[str] = 'array'
required_args: 't.ClassVar[set[str]]' = set()
class ArrayConstructCompact(sqlglot.expressions.core.Expression, sqlglot.expressions.core.Func):
30class ArrayConstructCompact(Expression, Func):
31    arg_types = {"expressions": False}
32    is_var_len_args = True
arg_types = {'expressions': False}
is_var_len_args = True
key: ClassVar[str] = 'arrayconstructcompact'
required_args: 't.ClassVar[set[str]]' = set()
35class List(Expression, Func):
36    arg_types = {"expressions": False}
37    is_var_len_args = True
arg_types = {'expressions': False}
is_var_len_args = True
key: ClassVar[str] = 'list'
required_args: 't.ClassVar[set[str]]' = set()
40class ToArray(Expression, Func):
41    pass
key: ClassVar[str] = 'toarray'
required_args: 't.ClassVar[set[str]]' = {'this'}
47class ArrayAppend(Expression, Func):
48    arg_types = {"this": True, "expression": True, "null_propagation": False}
arg_types = {'this': True, 'expression': True, 'null_propagation': False}
key: ClassVar[str] = 'arrayappend'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
51class ArrayCompact(Expression, Func):
52    pass
key: ClassVar[str] = 'arraycompact'
required_args: 't.ClassVar[set[str]]' = {'this'}
55class ArrayConcat(Expression, Func):
56    _sql_names = ["ARRAY_CONCAT", "ARRAY_CAT"]
57    arg_types = {"this": True, "expressions": False, "null_propagation": False}
58    is_var_len_args = True
arg_types = {'this': True, 'expressions': False, 'null_propagation': False}
is_var_len_args = True
key: ClassVar[str] = 'arrayconcat'
required_args: 't.ClassVar[set[str]]' = {'this'}
61class ArrayFilter(Expression, Func):
62    arg_types = {"this": True, "expression": True}
63    _sql_names = ["FILTER", "ARRAY_FILTER"]
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'arrayfilter'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
66class ArrayInsert(Expression, Func):
67    arg_types = {"this": True, "position": True, "expression": True, "offset": False}
arg_types = {'this': True, 'position': True, 'expression': True, 'offset': False}
key: ClassVar[str] = 'arrayinsert'
required_args: 't.ClassVar[set[str]]' = {'expression', 'position', 'this'}
70class ArrayPrepend(Expression, Func):
71    arg_types = {"this": True, "expression": True, "null_propagation": False}
arg_types = {'this': True, 'expression': True, 'null_propagation': False}
key: ClassVar[str] = 'arrayprepend'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
74class ArrayRemove(Expression, Func):
75    arg_types = {"this": True, "expression": True, "null_propagation": False}
arg_types = {'this': True, 'expression': True, 'null_propagation': False}
key: ClassVar[str] = 'arrayremove'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
78class ArrayRemoveAt(Expression, Func):
79    arg_types = {"this": True, "position": True}
arg_types = {'this': True, 'position': True}
key: ClassVar[str] = 'arrayremoveat'
required_args: 't.ClassVar[set[str]]' = {'position', 'this'}
82class ArrayReverse(Expression, Func):
83    pass
key: ClassVar[str] = 'arrayreverse'
required_args: 't.ClassVar[set[str]]' = {'this'}
86class ArraySlice(Expression, Func):
87    arg_types = {"this": True, "start": True, "end": False, "step": False, "zero_based": False}
arg_types = {'this': True, 'start': True, 'end': False, 'step': False, 'zero_based': False}
key: ClassVar[str] = 'arrayslice'
required_args: 't.ClassVar[set[str]]' = {'start', 'this'}
90class ArraySort(Expression, Func):
91    arg_types = {"this": True, "expression": False}
arg_types = {'this': True, 'expression': False}
key: ClassVar[str] = 'arraysort'
required_args: 't.ClassVar[set[str]]' = {'this'}
94class SortArray(Expression, Func):
95    arg_types = {"this": True, "asc": False, "nulls_first": False}
arg_types = {'this': True, 'asc': False, 'nulls_first': False}
key: ClassVar[str] = 'sortarray'
required_args: 't.ClassVar[set[str]]' = {'this'}
101class ArrayAll(Expression, Func):
102    arg_types = {"this": True, "expression": True}
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'arrayall'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
105class ArrayAny(Expression, Func):
106    arg_types = {"this": True, "expression": True}
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'arrayany'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
109class ArrayContains(Expression, Binary, Func):
110    arg_types = {"this": True, "expression": True, "ensure_variant": False, "check_null": False}
111    _sql_names = ["ARRAY_CONTAINS", "ARRAY_HAS"]
arg_types = {'this': True, 'expression': True, 'ensure_variant': False, 'check_null': False}
key: ClassVar[str] = 'arraycontains'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
114class ArrayContainsAll(Expression, Binary, Func):
115    _sql_names = ["ARRAY_CONTAINS_ALL", "ARRAY_HAS_ALL"]
key: ClassVar[str] = 'arraycontainsall'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
118class ArrayExcept(Expression, Func):
119    arg_types = {"this": True, "expression": True, "is_multiset": False}
arg_types = {'this': True, 'expression': True, 'is_multiset': False}
key: ClassVar[str] = 'arrayexcept'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
122class ArrayIntersect(Expression, Func):
123    arg_types = {"expressions": True, "is_multiset": False}
124    is_var_len_args = True
125    _sql_names = ["ARRAY_INTERSECT", "ARRAY_INTERSECTION"]
arg_types = {'expressions': True, 'is_multiset': False}
is_var_len_args = True
key: ClassVar[str] = 'arrayintersect'
required_args: 't.ClassVar[set[str]]' = {'expressions'}
128class ArrayOverlaps(Expression, Binary, Func):
129    arg_types = {"this": True, "expression": True, "null_safe": False}
arg_types = {'this': True, 'expression': True, 'null_safe': False}
key: ClassVar[str] = 'arrayoverlaps'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
132class ArrayPosition(Expression, Binary, Func):
133    arg_types = {"this": True, "expression": True, "zero_based": False}
arg_types = {'this': True, 'expression': True, 'zero_based': False}
key: ClassVar[str] = 'arrayposition'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
139class ArrayDistinct(Expression, Func):
140    arg_types = {"this": True, "check_null": False}
arg_types = {'this': True, 'check_null': False}
key: ClassVar[str] = 'arraydistinct'
required_args: 't.ClassVar[set[str]]' = {'this'}
143class ArrayFirst(Expression, Func):
144    arg_types = {"this": True, "expression": False}
arg_types = {'this': True, 'expression': False}
key: ClassVar[str] = 'arrayfirst'
required_args: 't.ClassVar[set[str]]' = {'this'}
147class ArrayLast(Expression, Func):
148    pass
key: ClassVar[str] = 'arraylast'
required_args: 't.ClassVar[set[str]]' = {'this'}
151class ArrayMax(Expression, Func):
152    pass
key: ClassVar[str] = 'arraymax'
required_args: 't.ClassVar[set[str]]' = {'this'}
155class ArrayMin(Expression, Func):
156    pass
key: ClassVar[str] = 'arraymin'
required_args: 't.ClassVar[set[str]]' = {'this'}
159class ArraySize(Expression, Func):
160    arg_types = {"this": True, "expression": False}
161    _sql_names = ["ARRAY_SIZE", "ARRAY_LENGTH"]
arg_types = {'this': True, 'expression': False}
key: ClassVar[str] = 'arraysize'
required_args: 't.ClassVar[set[str]]' = {'this'}
164class ArraySum(Expression, Func):
165    arg_types = {"this": True, "expression": False}
arg_types = {'this': True, 'expression': False}
key: ClassVar[str] = 'arraysum'
required_args: 't.ClassVar[set[str]]' = {'this'}
171class ArraysZip(Expression, Func):
172    arg_types = {"expressions": False}
173    is_var_len_args = True
arg_types = {'expressions': False}
is_var_len_args = True
key: ClassVar[str] = 'arrayszip'
required_args: 't.ClassVar[set[str]]' = set()
176class ArrayToString(Expression, Func):
177    arg_types = {
178        "this": True,
179        "expression": True,
180        "null": False,
181        "null_is_empty": False,
182        "null_delim_is_null": False,
183    }
184    _sql_names = ["ARRAY_TO_STRING", "ARRAY_JOIN"]
arg_types = {'this': True, 'expression': True, 'null': False, 'null_is_empty': False, 'null_delim_is_null': False}
key: ClassVar[str] = 'arraytostring'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
187class Flatten(Expression, Func):
188    pass
key: ClassVar[str] = 'flatten'
required_args: 't.ClassVar[set[str]]' = {'this'}
191class StringToArray(Expression, Func):
192    arg_types = {"this": True, "expression": False, "null": False}
193    _sql_names = ["STRING_TO_ARRAY", "SPLIT_BY_STRING"]
arg_types = {'this': True, 'expression': False, 'null': False}
key: ClassVar[str] = 'stringtoarray'
required_args: 't.ClassVar[set[str]]' = {'this'}
196class StrtokToArray(Expression, Func):
197    arg_types = {"this": True, "expression": False}
arg_types = {'this': True, 'expression': False}
key: ClassVar[str] = 'strtoktoarray'
required_args: 't.ClassVar[set[str]]' = {'this'}
203class Apply(Expression, Func):
204    arg_types = {"this": True, "expression": True}
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'apply'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
207class Reduce(Expression, Func):
208    arg_types = {"this": True, "initial": True, "merge": True, "finish": False}
arg_types = {'this': True, 'initial': True, 'merge': True, 'finish': False}
key: ClassVar[str] = 'reduce'
required_args: 't.ClassVar[set[str]]' = {'merge', 'this', 'initial'}
211class Transform(Expression, Func):
212    arg_types = {"this": True, "expression": True}
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'transform'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
218class GenerateSeries(Expression, Func):
219    arg_types = {"start": True, "end": True, "step": False, "is_end_exclusive": False}
arg_types = {'start': True, 'end': True, 'step': False, 'is_end_exclusive': False}
key: ClassVar[str] = 'generateseries'
required_args: 't.ClassVar[set[str]]' = {'end', 'start'}
class ExplodingGenerateSeries(GenerateSeries):
222class ExplodingGenerateSeries(GenerateSeries):
223    pass
key: ClassVar[str] = 'explodinggenerateseries'
required_args: 't.ClassVar[set[str]]' = {'end', 'start'}
226class Generator(Expression, Func, UDTF):
227    arg_types = {"rowcount": False, "timelimit": False}
arg_types = {'rowcount': False, 'timelimit': False}
key: ClassVar[str] = 'generator'
required_args: 't.ClassVar[set[str]]' = set()
230class Explode(Expression, Func, UDTF):
231    arg_types = {"this": True, "expressions": False}
232    is_var_len_args = True
arg_types = {'this': True, 'expressions': False}
is_var_len_args = True
key: ClassVar[str] = 'explode'
required_args: 't.ClassVar[set[str]]' = {'this'}
235class Inline(Expression, Func):
236    pass
key: ClassVar[str] = 'inline'
required_args: 't.ClassVar[set[str]]' = {'this'}
@trait
class ExplodeOuter(sqlglot.expressions.core.Expr):
239@trait
240class ExplodeOuter(Expr):
241    pass
key: ClassVar[str] = 'explodeouter'
required_args: 't.ClassVar[set[str]]' = {'this'}
class Posexplode(Explode):
248class Posexplode(Explode):
249    pass
key: ClassVar[str] = 'posexplode'
required_args: 't.ClassVar[set[str]]' = {'this'}
class PosexplodeOuter(Posexplode, ExplodeOuter):
252class PosexplodeOuter(Posexplode, ExplodeOuter):
253    pass
key: ClassVar[str] = 'posexplodeouter'
required_args: 't.ClassVar[set[str]]' = {'this'}
class PositionalColumn(sqlglot.expressions.core.Expression):
256class PositionalColumn(Expression):
257    pass
key: ClassVar[str] = 'positionalcolumn'
required_args: 't.ClassVar[set[str]]' = {'this'}
260class Unnest(Expression, Func, UDTF):
261    arg_types = {
262        "expressions": True,
263        "alias": False,
264        "offset": False,
265        "explode_array": False,
266    }
267
268    @property
269    def selects(self) -> list[Expr]:
270        columns = super().selects
271        offset = self.args.get("offset")
272        if offset:
273            columns = columns + [to_identifier("offset") if offset is True else offset]
274        return columns
arg_types = {'expressions': True, 'alias': False, 'offset': False, 'explode_array': False}
selects: list[sqlglot.expressions.core.Expr]
268    @property
269    def selects(self) -> list[Expr]:
270        columns = super().selects
271        offset = self.args.get("offset")
272        if offset:
273            columns = columns + [to_identifier("offset") if offset is True else offset]
274        return columns
key: ClassVar[str] = 'unnest'
required_args: 't.ClassVar[set[str]]' = {'expressions'}
280class Map(Expression, Func):
281    arg_types = {"keys": False, "values": False}
282
283    @property
284    def keys(self) -> list[Expr]:
285        keys = self.args.get("keys")
286        return keys.expressions if keys else []
287
288    @property
289    def values(self) -> list[Expr]:
290        values = self.args.get("values")
291        return values.expressions if values else []
arg_types = {'keys': False, 'values': False}
keys: list[sqlglot.expressions.core.Expr]
283    @property
284    def keys(self) -> list[Expr]:
285        keys = self.args.get("keys")
286        return keys.expressions if keys else []
values: list[sqlglot.expressions.core.Expr]
288    @property
289    def values(self) -> list[Expr]:
290        values = self.args.get("values")
291        return values.expressions if values else []
key: ClassVar[str] = 'map'
required_args: 't.ClassVar[set[str]]' = set()
294class MapCat(Expression, Func):
295    arg_types = {"this": True, "expression": True}
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'mapcat'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
298class MapContainsKey(Expression, Func):
299    arg_types = {"this": True, "key": True}
arg_types = {'this': True, 'key': True}
key: ClassVar[str] = 'mapcontainskey'
required_args: 't.ClassVar[set[str]]' = {'key', 'this'}
302class MapDelete(Expression, Func):
303    arg_types = {"this": True, "expressions": True}
304    is_var_len_args = True
arg_types = {'this': True, 'expressions': True}
is_var_len_args = True
key: ClassVar[str] = 'mapdelete'
required_args: 't.ClassVar[set[str]]' = {'this', 'expressions'}
307class MapFromEntries(Expression, Func):
308    pass
key: ClassVar[str] = 'mapfromentries'
required_args: 't.ClassVar[set[str]]' = {'this'}
311class MapInsert(Expression, Func):
312    arg_types = {"this": True, "key": False, "value": True, "update_flag": False}
arg_types = {'this': True, 'key': False, 'value': True, 'update_flag': False}
key: ClassVar[str] = 'mapinsert'
required_args: 't.ClassVar[set[str]]' = {'this', 'value'}
315class MapKeys(Expression, Func):
316    pass
key: ClassVar[str] = 'mapkeys'
required_args: 't.ClassVar[set[str]]' = {'this'}
319class MapPick(Expression, Func):
320    arg_types = {"this": True, "expressions": True}
321    is_var_len_args = True
arg_types = {'this': True, 'expressions': True}
is_var_len_args = True
key: ClassVar[str] = 'mappick'
required_args: 't.ClassVar[set[str]]' = {'this', 'expressions'}
324class MapSize(Expression, Func):
325    pass
key: ClassVar[str] = 'mapsize'
required_args: 't.ClassVar[set[str]]' = {'this'}
328class StarMap(Expression, Func):
329    pass
key: ClassVar[str] = 'starmap'
required_args: 't.ClassVar[set[str]]' = {'this'}
332class ToMap(Expression, Func):
333    pass
key: ClassVar[str] = 'tomap'
required_args: 't.ClassVar[set[str]]' = {'this'}
336class VarMap(Expression, Func):
337    arg_types = {"keys": True, "values": True}
338    is_var_len_args = True
339
340    @property
341    def keys(self) -> list[Expr]:
342        return self.args["keys"].expressions
343
344    @property
345    def values(self) -> list[Expr]:
346        return self.args["values"].expressions
arg_types = {'keys': True, 'values': True}
is_var_len_args = True
keys: list[sqlglot.expressions.core.Expr]
340    @property
341    def keys(self) -> list[Expr]:
342        return self.args["keys"].expressions
values: list[sqlglot.expressions.core.Expr]
344    @property
345    def values(self) -> list[Expr]:
346        return self.args["values"].expressions
key: ClassVar[str] = 'varmap'
required_args: 't.ClassVar[set[str]]' = {'values', 'keys'}
352class Struct(Expression, Func):
353    arg_types = {"expressions": False}
354    is_var_len_args = True
arg_types = {'expressions': False}
is_var_len_args = True
key: ClassVar[str] = 'struct'
required_args: 't.ClassVar[set[str]]' = set()
357class StructExtract(Expression, Func):
358    arg_types = {"this": True, "expression": True}
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'structextract'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
364class StDistance(Expression, Func):
365    arg_types = {"this": True, "expression": True, "use_spheroid": False}
arg_types = {'this': True, 'expression': True, 'use_spheroid': False}
key: ClassVar[str] = 'stdistance'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
368class StPoint(Expression, Func):
369    arg_types = {"this": True, "expression": True, "z": False, "m": False}
370    _sql_names = ["ST_POINT", "ST_MAKEPOINT"]
arg_types = {'this': True, 'expression': True, 'z': False, 'm': False}
key: ClassVar[str] = 'stpoint'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}