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", "STRTOK_TO_ARRAY"]
193
194
195# Higher-order / lambda
196
197
198class Apply(Expression, Func):
199    arg_types = {"this": True, "expression": True}
200
201
202class Reduce(Expression, Func):
203    arg_types = {"this": True, "initial": True, "merge": True, "finish": False}
204
205
206class Transform(Expression, Func):
207    arg_types = {"this": True, "expression": True}
208
209
210# Table-valued / UDTF
211
212
213class GenerateSeries(Expression, Func):
214    arg_types = {"start": True, "end": True, "step": False, "is_end_exclusive": False}
215
216
217class ExplodingGenerateSeries(GenerateSeries):
218    pass
219
220
221class Generator(Expression, Func, UDTF):
222    arg_types = {"rowcount": False, "timelimit": False}
223
224
225class Explode(Expression, Func, UDTF):
226    arg_types = {"this": True, "expressions": False}
227    is_var_len_args = True
228
229
230class Inline(Expression, Func):
231    pass
232
233
234@trait
235class ExplodeOuter(Expr):
236    pass
237
238
239class _ExplodeOuter(Explode, ExplodeOuter):
240    _sql_names = ["EXPLODE_OUTER"]
241
242
243class Posexplode(Explode):
244    pass
245
246
247class PosexplodeOuter(Posexplode, ExplodeOuter):
248    pass
249
250
251class PositionalColumn(Expression):
252    pass
253
254
255class Unnest(Expression, Func, UDTF):
256    arg_types = {
257        "expressions": True,
258        "alias": False,
259        "offset": False,
260        "explode_array": False,
261    }
262
263    @property
264    def selects(self) -> list[Expr]:
265        columns = super().selects
266        offset = self.args.get("offset")
267        if offset:
268            columns = columns + [to_identifier("offset") if offset is True else offset]
269        return columns
270
271
272# Map
273
274
275class Map(Expression, Func):
276    arg_types = {"keys": False, "values": False}
277
278    @property
279    def keys(self) -> list[Expr]:
280        keys = self.args.get("keys")
281        return keys.expressions if keys else []
282
283    @property
284    def values(self) -> list[Expr]:
285        values = self.args.get("values")
286        return values.expressions if values else []
287
288
289class MapCat(Expression, Func):
290    arg_types = {"this": True, "expression": True}
291
292
293class MapContainsKey(Expression, Func):
294    arg_types = {"this": True, "key": True}
295
296
297class MapDelete(Expression, Func):
298    arg_types = {"this": True, "expressions": True}
299    is_var_len_args = True
300
301
302class MapFromEntries(Expression, Func):
303    pass
304
305
306class MapInsert(Expression, Func):
307    arg_types = {"this": True, "key": False, "value": True, "update_flag": False}
308
309
310class MapKeys(Expression, Func):
311    pass
312
313
314class MapPick(Expression, Func):
315    arg_types = {"this": True, "expressions": True}
316    is_var_len_args = True
317
318
319class MapSize(Expression, Func):
320    pass
321
322
323class StarMap(Expression, Func):
324    pass
325
326
327class ToMap(Expression, Func):
328    pass
329
330
331class VarMap(Expression, Func):
332    arg_types = {"keys": True, "values": True}
333    is_var_len_args = True
334
335    @property
336    def keys(self) -> list[Expr]:
337        return self.args["keys"].expressions
338
339    @property
340    def values(self) -> list[Expr]:
341        return self.args["values"].expressions
342
343
344# Struct
345
346
347class Struct(Expression, Func):
348    arg_types = {"expressions": False}
349    is_var_len_args = True
350
351
352class StructExtract(Expression, Func):
353    arg_types = {"this": True, "expression": True}
354
355
356# Geospatial
357
358
359class StDistance(Expression, Func):
360    arg_types = {"this": True, "expression": True, "use_spheroid": False}
361
362
363class StPoint(Expression, Func):
364    arg_types = {"this": True, "expression": True, "null": False}
365    _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]]' = {'position', 'expression', '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", "STRTOK_TO_ARRAY"]
arg_types = {'this': True, 'expression': False, 'null': False}
key: ClassVar[str] = 'stringtoarray'
required_args: 't.ClassVar[set[str]]' = {'this'}
199class Apply(Expression, Func):
200    arg_types = {"this": True, "expression": True}
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'apply'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
203class Reduce(Expression, Func):
204    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]]' = {'initial', 'this', 'merge'}
207class Transform(Expression, Func):
208    arg_types = {"this": True, "expression": True}
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'transform'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
214class GenerateSeries(Expression, Func):
215    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]]' = {'start', 'end'}
class ExplodingGenerateSeries(GenerateSeries):
218class ExplodingGenerateSeries(GenerateSeries):
219    pass
key: ClassVar[str] = 'explodinggenerateseries'
required_args: 't.ClassVar[set[str]]' = {'start', 'end'}
222class Generator(Expression, Func, UDTF):
223    arg_types = {"rowcount": False, "timelimit": False}
arg_types = {'rowcount': False, 'timelimit': False}
key: ClassVar[str] = 'generator'
required_args: 't.ClassVar[set[str]]' = set()
226class Explode(Expression, Func, UDTF):
227    arg_types = {"this": True, "expressions": False}
228    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'}
231class Inline(Expression, Func):
232    pass
key: ClassVar[str] = 'inline'
required_args: 't.ClassVar[set[str]]' = {'this'}
@trait
class ExplodeOuter(sqlglot.expressions.core.Expr):
235@trait
236class ExplodeOuter(Expr):
237    pass
key: ClassVar[str] = 'explodeouter'
required_args: 't.ClassVar[set[str]]' = {'this'}
class Posexplode(Explode):
244class Posexplode(Explode):
245    pass
key: ClassVar[str] = 'posexplode'
required_args: 't.ClassVar[set[str]]' = {'this'}
class PosexplodeOuter(Posexplode, ExplodeOuter):
248class PosexplodeOuter(Posexplode, ExplodeOuter):
249    pass
key: ClassVar[str] = 'posexplodeouter'
required_args: 't.ClassVar[set[str]]' = {'this'}
class PositionalColumn(sqlglot.expressions.core.Expression):
252class PositionalColumn(Expression):
253    pass
key: ClassVar[str] = 'positionalcolumn'
required_args: 't.ClassVar[set[str]]' = {'this'}
256class Unnest(Expression, Func, UDTF):
257    arg_types = {
258        "expressions": True,
259        "alias": False,
260        "offset": False,
261        "explode_array": False,
262    }
263
264    @property
265    def selects(self) -> list[Expr]:
266        columns = super().selects
267        offset = self.args.get("offset")
268        if offset:
269            columns = columns + [to_identifier("offset") if offset is True else offset]
270        return columns
arg_types = {'expressions': True, 'alias': False, 'offset': False, 'explode_array': False}
selects: list[sqlglot.expressions.core.Expr]
264    @property
265    def selects(self) -> list[Expr]:
266        columns = super().selects
267        offset = self.args.get("offset")
268        if offset:
269            columns = columns + [to_identifier("offset") if offset is True else offset]
270        return columns
key: ClassVar[str] = 'unnest'
required_args: 't.ClassVar[set[str]]' = {'expressions'}
276class Map(Expression, Func):
277    arg_types = {"keys": False, "values": False}
278
279    @property
280    def keys(self) -> list[Expr]:
281        keys = self.args.get("keys")
282        return keys.expressions if keys else []
283
284    @property
285    def values(self) -> list[Expr]:
286        values = self.args.get("values")
287        return values.expressions if values else []
arg_types = {'keys': False, 'values': False}
keys: list[sqlglot.expressions.core.Expr]
279    @property
280    def keys(self) -> list[Expr]:
281        keys = self.args.get("keys")
282        return keys.expressions if keys else []
values: list[sqlglot.expressions.core.Expr]
284    @property
285    def values(self) -> list[Expr]:
286        values = self.args.get("values")
287        return values.expressions if values else []
key: ClassVar[str] = 'map'
required_args: 't.ClassVar[set[str]]' = set()
290class MapCat(Expression, Func):
291    arg_types = {"this": True, "expression": True}
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'mapcat'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
294class MapContainsKey(Expression, Func):
295    arg_types = {"this": True, "key": True}
arg_types = {'this': True, 'key': True}
key: ClassVar[str] = 'mapcontainskey'
required_args: 't.ClassVar[set[str]]' = {'key', 'this'}
298class MapDelete(Expression, Func):
299    arg_types = {"this": True, "expressions": True}
300    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]]' = {'expressions', 'this'}
303class MapFromEntries(Expression, Func):
304    pass
key: ClassVar[str] = 'mapfromentries'
required_args: 't.ClassVar[set[str]]' = {'this'}
307class MapInsert(Expression, Func):
308    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]]' = {'value', 'this'}
311class MapKeys(Expression, Func):
312    pass
key: ClassVar[str] = 'mapkeys'
required_args: 't.ClassVar[set[str]]' = {'this'}
315class MapPick(Expression, Func):
316    arg_types = {"this": True, "expressions": True}
317    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]]' = {'expressions', 'this'}
320class MapSize(Expression, Func):
321    pass
key: ClassVar[str] = 'mapsize'
required_args: 't.ClassVar[set[str]]' = {'this'}
324class StarMap(Expression, Func):
325    pass
key: ClassVar[str] = 'starmap'
required_args: 't.ClassVar[set[str]]' = {'this'}
328class ToMap(Expression, Func):
329    pass
key: ClassVar[str] = 'tomap'
required_args: 't.ClassVar[set[str]]' = {'this'}
332class VarMap(Expression, Func):
333    arg_types = {"keys": True, "values": True}
334    is_var_len_args = True
335
336    @property
337    def keys(self) -> list[Expr]:
338        return self.args["keys"].expressions
339
340    @property
341    def values(self) -> list[Expr]:
342        return self.args["values"].expressions
arg_types = {'keys': True, 'values': True}
is_var_len_args = True
keys: list[sqlglot.expressions.core.Expr]
336    @property
337    def keys(self) -> list[Expr]:
338        return self.args["keys"].expressions
values: list[sqlglot.expressions.core.Expr]
340    @property
341    def values(self) -> list[Expr]:
342        return self.args["values"].expressions
key: ClassVar[str] = 'varmap'
required_args: 't.ClassVar[set[str]]' = {'values', 'keys'}
348class Struct(Expression, Func):
349    arg_types = {"expressions": False}
350    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()
353class StructExtract(Expression, Func):
354    arg_types = {"this": True, "expression": True}
arg_types = {'this': True, 'expression': True}
key: ClassVar[str] = 'structextract'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}
360class StDistance(Expression, Func):
361    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'}
364class StPoint(Expression, Func):
365    arg_types = {"this": True, "expression": True, "null": False}
366    _sql_names = ["ST_POINT", "ST_MAKEPOINT"]
arg_types = {'this': True, 'expression': True, 'null': False}
key: ClassVar[str] = 'stpoint'
required_args: 't.ClassVar[set[str]]' = {'expression', 'this'}