sqlglot.parsers.snowflake
1from __future__ import annotations 2 3import typing as t 4 5from sqlglot import exp, parser 6from sqlglot.trie import new_trie 7from sqlglot.dialects.dialect import ( 8 Dialect, 9 build_default_decimal_type, 10 build_formatted_time, 11 build_like, 12 build_replace_with_optional_replacement, 13 build_timetostr_or_tochar, 14 build_trunc, 15 binary_from_function, 16 date_trunc_to_time, 17 map_date_part, 18) 19from sqlglot.helper import is_date_unit, is_int, seq_get 20from sqlglot.tokens import TokenType 21 22if t.TYPE_CHECKING: 23 from collections.abc import Collection 24 from sqlglot._typing import B, E 25 from sqlglot.dialects.dialect import Dialect 26 27 28def _build_approx_top_k(args: list) -> exp.ApproxTopK: 29 """ 30 Normalizes APPROX_TOP_K arguments to match Snowflake semantics. 31 32 Snowflake APPROX_TOP_K signature: APPROX_TOP_K(column [, k] [, counters]) 33 - k defaults to 1 if omitted (per Snowflake documentation) 34 - counters is optional precision parameter 35 """ 36 # Add default k=1 if only column is provided 37 if len(args) == 1: 38 args.append(exp.Literal.number(1)) 39 40 return exp.ApproxTopK.from_arg_list(args) 41 42 43def _build_to_number(args: list, safe: bool = False) -> exp.ToNumber: 44 second_arg = seq_get(args, 1) 45 if second_arg and second_arg.is_number: 46 fmt = None 47 precision = second_arg 48 scale = seq_get(args, 2) or exp.Literal.number(0) 49 else: 50 fmt = second_arg 51 precision = seq_get(args, 2) or exp.Literal.number(38) 52 scale = seq_get(args, 3) or exp.Literal.number(0) 53 54 return exp.ToNumber( 55 this=seq_get(args, 0), 56 format=fmt, 57 precision=precision, 58 scale=scale, 59 safe=safe, 60 ) 61 62 63def _build_date_from_parts(args: list) -> exp.DateFromParts: 64 return exp.DateFromParts( 65 year=seq_get(args, 0), 66 month=seq_get(args, 1), 67 day=seq_get(args, 2), 68 allow_overflow=True, 69 ) 70 71 72# Timestamp types used in _build_datetime 73TIMESTAMP_TYPES = { 74 exp.DType.TIMESTAMP: "TO_TIMESTAMP", 75 exp.DType.TIMESTAMPLTZ: "TO_TIMESTAMP_LTZ", 76 exp.DType.TIMESTAMPNTZ: "TO_TIMESTAMP_NTZ", 77 exp.DType.TIMESTAMPTZ: "TO_TIMESTAMP_TZ", 78} 79 80 81def _build_datetime(name: str, kind: exp.DType, safe: bool = False) -> t.Callable: 82 def _builder(args: list, dialect: Dialect) -> exp.Func: 83 value = seq_get(args, 0) 84 scale_or_fmt = seq_get(args, 1) 85 86 int_value = value is not None and is_int(value.name) 87 int_scale_or_fmt = scale_or_fmt is not None and scale_or_fmt.is_int 88 89 if isinstance(value, (exp.Literal, exp.Neg)) or (value and scale_or_fmt): 90 # Converts calls like `TO_TIME('01:02:03')` into casts 91 if len(args) == 1 and value.is_string and not int_value: 92 cast = ( 93 exp.TryCast(this=value, to=kind.into_expr(), requires_string=True) 94 if safe 95 else exp.cast(value, kind) 96 ) 97 if safe and kind == exp.DType.DATE: 98 cast.set("probe_date_format", True) 99 return cast 100 101 # Handles `TO_TIMESTAMP(str, fmt)` and `TO_TIMESTAMP(num, scale)` as special 102 # cases so we can transpile them, since they're relatively common 103 if kind in TIMESTAMP_TYPES: 104 if not safe and (int_scale_or_fmt or (int_value and scale_or_fmt is None)): 105 # TRY_TO_TIMESTAMP('integer') is not parsed into exp.UnixToTime as 106 # it's not easily transpilable. Also, numeric-looking strings with 107 # format strings (e.g., TO_TIMESTAMP('20240115', 'YYYYMMDD')) should 108 # use StrToTime, not UnixToTime. 109 unix_expr = exp.UnixToTime(this=value, scale=scale_or_fmt) 110 unix_expr.set("target_type", kind.into_expr()) 111 return unix_expr 112 if scale_or_fmt and not int_scale_or_fmt: 113 # Format string provided (e.g., 'YYYY-MM-DD'), use StrToTime 114 strtotime_expr = build_formatted_time(exp.StrToTime)(args, dialect) 115 strtotime_expr.set("safe", safe) 116 strtotime_expr.set("target_type", kind.into_expr()) 117 return strtotime_expr 118 119 # Handle DATE/TIME with format strings - allow int_value if a format string is provided 120 has_format_string = scale_or_fmt and not int_scale_or_fmt 121 if kind in (exp.DType.DATE, exp.DType.TIME) and (not int_value or has_format_string): 122 klass = exp.TsOrDsToDate if kind == exp.DType.DATE else exp.TsOrDsToTime 123 formatted_exp = build_formatted_time(klass)(args, dialect) 124 formatted_exp.set("safe", safe) 125 return formatted_exp 126 127 return exp.Anonymous(this=name, expressions=args) 128 129 return _builder 130 131 132def _build_bitwise(expr_type: type[B], name: str) -> t.Callable[[list], B | exp.Anonymous]: 133 def _builder(args: list) -> B | exp.Anonymous: 134 if len(args) == 3: 135 # Special handling for bitwise operations with padside argument 136 if expr_type in (exp.BitwiseAnd, exp.BitwiseOr, exp.BitwiseXor): 137 return expr_type( 138 this=seq_get(args, 0), expression=seq_get(args, 1), padside=seq_get(args, 2) 139 ) 140 return exp.Anonymous(this=name, expressions=args) 141 142 result = binary_from_function(expr_type)(args) 143 144 # Snowflake specifies INT128 for bitwise shifts 145 if expr_type in (exp.BitwiseLeftShift, exp.BitwiseRightShift): 146 result.set("requires_int128", True) 147 148 return result 149 150 return _builder 151 152 153# https://docs.snowflake.com/en/sql-reference/functions/div0 154def _build_if_from_div0(args: list) -> exp.If: 155 lhs = exp._wrap(seq_get(args, 0), exp.Binary) 156 rhs = exp._wrap(seq_get(args, 1), exp.Binary) 157 158 cond = exp.EQ(this=rhs, expression=exp.Literal.number(0)).and_( 159 exp.Is(this=lhs, expression=exp.null()).not_() 160 ) 161 true = exp.Literal.number(0) 162 false = exp.Div(this=lhs, expression=rhs) 163 return exp.If(this=cond, true=true, false=false) 164 165 166# https://docs.snowflake.com/en/sql-reference/functions/div0null 167def _build_if_from_div0null(args: list) -> exp.If: 168 lhs = exp._wrap(seq_get(args, 0), exp.Binary) 169 rhs = exp._wrap(seq_get(args, 1), exp.Binary) 170 171 # Returns 0 when divisor is 0 OR NULL 172 cond = exp.EQ(this=rhs, expression=exp.Literal.number(0)).or_( 173 exp.Is(this=rhs, expression=exp.null()) 174 ) 175 true = exp.Literal.number(0) 176 false = exp.Div(this=lhs, expression=rhs) 177 return exp.If(this=cond, true=true, false=false) 178 179 180# https://docs.snowflake.com/en/sql-reference/functions/zeroifnull 181def _build_if_from_zeroifnull(args: list) -> exp.If: 182 cond = exp.Is(this=seq_get(args, 0), expression=exp.Null()) 183 return exp.If(this=cond, true=exp.Literal.number(0), false=seq_get(args, 0)) 184 185 186def _build_search(args: list) -> exp.Search: 187 kwargs = { 188 "this": seq_get(args, 0), 189 "expression": seq_get(args, 1), 190 **{arg.name.lower(): arg for arg in args[2:] if isinstance(arg, exp.Kwarg)}, 191 } 192 return exp.Search(**kwargs) 193 194 195# https://docs.snowflake.com/en/sql-reference/functions/zeroifnull 196def _build_if_from_nullifzero(args: list) -> exp.If: 197 cond = exp.EQ(this=seq_get(args, 0), expression=exp.Literal.number(0)) 198 return exp.If(this=cond, true=exp.Null(), false=seq_get(args, 0)) 199 200 201def _build_regexp_replace(args: list) -> exp.RegexpReplace: 202 regexp_replace = exp.RegexpReplace.from_arg_list(args) 203 204 if not regexp_replace.args.get("replacement"): 205 regexp_replace.set("replacement", exp.Literal.string("")) 206 207 return regexp_replace 208 209 210def _build_regexp_like(args: list) -> exp.RegexpLike: 211 return exp.RegexpLike( 212 this=seq_get(args, 0), 213 expression=seq_get(args, 1), 214 flag=seq_get(args, 2), 215 full_match=True, 216 ) 217 218 219def _date_trunc_to_time(args: list) -> exp.DateTrunc | exp.TimestampTrunc: 220 trunc = date_trunc_to_time(args) 221 unit = map_date_part(trunc.args["unit"]) 222 trunc.set("unit", unit) 223 is_time_input = trunc.this.is_type(exp.DType.TIME, exp.DType.TIMETZ) 224 if (isinstance(trunc, exp.TimestampTrunc) and is_date_unit(unit) or is_time_input) or ( 225 isinstance(trunc, exp.DateTrunc) and not is_date_unit(unit) 226 ): 227 trunc.set("input_type_preserved", True) 228 return trunc 229 230 231def _build_regexp_extract(expr_type: type[E]) -> t.Callable[[list, Dialect], E]: 232 def _builder(args: list, dialect: Dialect) -> E: 233 return expr_type( 234 this=seq_get(args, 0), 235 expression=seq_get(args, 1), 236 position=seq_get(args, 2), 237 occurrence=seq_get(args, 3), 238 parameters=seq_get(args, 4), 239 group=seq_get(args, 5) or exp.Literal.number(0), 240 **( 241 {"null_if_pos_overflow": dialect.REGEXP_EXTRACT_POSITION_OVERFLOW_RETURNS_NULL} 242 if expr_type is exp.RegexpExtract 243 else {} 244 ), 245 ) 246 247 return _builder 248 249 250def _build_timestamp_from_parts(args: list) -> exp.Func: 251 """Build TimestampFromParts with support for both syntaxes: 252 1. TIMESTAMP_FROM_PARTS(year, month, day, hour, minute, second [, nanosecond] [, time_zone]) 253 2. TIMESTAMP_FROM_PARTS(date_expr, time_expr) - Snowflake specific 254 """ 255 if len(args) == 2: 256 return exp.TimestampFromParts(this=seq_get(args, 0), expression=seq_get(args, 1)) 257 258 return exp.TimestampFromParts.from_arg_list(args) 259 260 261def _build_round(args: list) -> exp.Round: 262 """ 263 Build Round expression, unwrapping Snowflake's named parameters. 264 265 Maps EXPR => this, SCALE => decimals, ROUNDING_MODE => truncate. 266 267 Note: Snowflake does not support mixing named and positional arguments. 268 Arguments are either all named or all positional. 269 """ 270 kwarg_map = {"EXPR": "this", "SCALE": "decimals", "ROUNDING_MODE": "truncate"} 271 round_args = {} 272 positional_keys = ["this", "decimals", "truncate"] 273 positional_idx = 0 274 275 for arg in args: 276 if isinstance(arg, exp.Kwarg): 277 key = arg.this.name.upper() 278 round_key = kwarg_map.get(key) 279 if round_key: 280 round_args[round_key] = arg.expression 281 else: 282 if positional_idx < len(positional_keys): 283 round_args[positional_keys[positional_idx]] = arg 284 positional_idx += 1 285 286 expression = exp.Round(**round_args) 287 expression.set("casts_non_integer_decimals", True) 288 return expression 289 290 291def _build_array_sort(args: list) -> exp.SortArray: 292 asc = seq_get(args, 1) 293 nulls_first = seq_get(args, 2) 294 if nulls_first is None and isinstance(asc, exp.Boolean): 295 nulls_first = exp.Boolean(this=not asc.this) 296 return exp.SortArray(this=seq_get(args, 0), asc=asc, nulls_first=nulls_first) 297 298 299def _build_generator(args: list) -> exp.Generator: 300 """ 301 Build Generator expression, unwrapping Snowflake's named parameters. 302 303 Maps ROWCOUNT => rowcount, TIMELIMIT => timelimit. 304 """ 305 kwarg_map = {"ROWCOUNT": "rowcount", "TIMELIMIT": "timelimit"} 306 gen_args = {} 307 308 positional_keys = ("rowcount", "timelimit") 309 310 for i, arg in enumerate(args): 311 if isinstance(arg, exp.Kwarg): 312 key = arg.this.name.upper() 313 gen_key = kwarg_map.get(key) 314 if gen_key: 315 gen_args[gen_key] = arg.expression 316 elif i < len(positional_keys): 317 gen_args[positional_keys[i]] = arg 318 319 return exp.Generator(**gen_args) 320 321 322def _show_parser(*args: t.Any, **kwargs: t.Any) -> t.Callable[[SnowflakeParser], exp.Show]: 323 def _parse(self: SnowflakeParser) -> exp.Show: 324 return self._parse_show_snowflake(*args, **kwargs) 325 326 return _parse 327 328 329class SnowflakeParser(parser.Parser): 330 IDENTIFY_PIVOT_STRINGS = True 331 TYPED_LAMBDA_ARGS = True 332 DEFAULT_SAMPLING_METHOD = "BERNOULLI" 333 COLON_IS_VARIANT_EXTRACT = True 334 JSON_EXTRACT_REQUIRES_JSON_EXPRESSION = True 335 336 TYPE_TOKENS = {*parser.Parser.TYPE_TOKENS, TokenType.FILE} 337 STRUCT_TYPE_TOKENS = {*parser.Parser.STRUCT_TYPE_TOKENS, TokenType.FILE} 338 NESTED_TYPE_TOKENS = {*parser.Parser.NESTED_TYPE_TOKENS, TokenType.FILE} 339 340 ID_VAR_TOKENS = { 341 *parser.Parser.ID_VAR_TOKENS, 342 TokenType.EXCEPT, 343 TokenType.INTEGRATION, 344 TokenType.MATCH_CONDITION, 345 TokenType.PACKAGE, 346 TokenType.POLICY, 347 TokenType.POOL, 348 TokenType.ROLE, 349 TokenType.RULE, 350 TokenType.VOLUME, 351 } 352 353 ALIAS_TOKENS = parser.Parser.ALIAS_TOKENS | { 354 TokenType.INTEGRATION, 355 TokenType.PACKAGE, 356 TokenType.POLICY, 357 TokenType.POOL, 358 TokenType.ROLE, 359 TokenType.RULE, 360 TokenType.VOLUME, 361 } 362 363 TABLE_ALIAS_TOKENS = ( 364 parser.Parser.TABLE_ALIAS_TOKENS 365 | { 366 TokenType.ANTI, 367 TokenType.INTEGRATION, 368 TokenType.PACKAGE, 369 TokenType.POLICY, 370 TokenType.POOL, 371 TokenType.ROLE, 372 TokenType.RULE, 373 TokenType.SEMI, 374 TokenType.VOLUME, 375 TokenType.WINDOW, 376 } 377 ) - {TokenType.MATCH_CONDITION} 378 379 COLON_PLACEHOLDER_TOKENS = ID_VAR_TOKENS | {TokenType.NUMBER} 380 381 NO_PAREN_FUNCTIONS = { 382 **parser.Parser.NO_PAREN_FUNCTIONS, 383 TokenType.LOCALTIME: exp.Localtime, 384 TokenType.LOCALTIMESTAMP: exp.Localtimestamp, 385 TokenType.CURRENT_TIME: exp.Localtime, 386 } 387 388 RANGE_PARSERS = { 389 **parser.Parser.RANGE_PARSERS, 390 TokenType.RLIKE: lambda self, this: self.expression( 391 exp.RegexpLike(this=this, expression=self._parse_bitwise(), full_match=True) 392 ), 393 } 394 395 FUNCTIONS = { 396 **parser.Parser.FUNCTIONS, 397 "CHARINDEX": lambda args: exp.StrPosition( 398 this=seq_get(args, 1), 399 substr=seq_get(args, 0), 400 position=seq_get(args, 2), 401 clamp_position=True, 402 ), 403 "ADD_MONTHS": lambda args: exp.AddMonths( 404 this=seq_get(args, 0), 405 expression=seq_get(args, 1), 406 preserve_end_of_month=True, 407 ), 408 "APPROX_PERCENTILE": exp.ApproxQuantile.from_arg_list, 409 "CURRENT_TIME": lambda args: exp.Localtime(this=seq_get(args, 0)), 410 "APPROX_TOP_K": _build_approx_top_k, 411 "ARRAY_CONSTRUCT": lambda args: exp.Array(expressions=args), 412 "ARRAY_CONTAINS": lambda args: exp.ArrayContains( 413 this=seq_get(args, 1), 414 expression=seq_get(args, 0), 415 ensure_variant=False, 416 check_null=True, 417 ), 418 "ARRAY_DISTINCT": lambda args: exp.ArrayDistinct( 419 this=seq_get(args, 0), 420 check_null=True, 421 ), 422 "ARRAY_GENERATE_RANGE": lambda args: exp.GenerateSeries( 423 # Snowflake has exclusive end semantics 424 start=seq_get(args, 0), 425 end=seq_get(args, 1), 426 step=seq_get(args, 2), 427 is_end_exclusive=True, 428 ), 429 "ARRAY_EXCEPT": lambda args: exp.ArrayExcept( 430 this=seq_get(args, 0), 431 expression=seq_get(args, 1), 432 is_multiset=True, 433 ), 434 "ARRAY_INTERSECTION": lambda args: exp.ArrayIntersect( 435 expressions=args, 436 is_multiset=True, 437 ), 438 "ARRAY_POSITION": lambda args: exp.ArrayPosition( 439 this=seq_get(args, 1), 440 expression=seq_get(args, 0), 441 zero_based=True, 442 ), 443 "ARRAY_SLICE": lambda args: exp.ArraySlice( 444 this=seq_get(args, 0), 445 start=seq_get(args, 1), 446 end=seq_get(args, 2), 447 zero_based=True, 448 ), 449 "ARRAY_SORT": _build_array_sort, 450 "ARRAY_FLATTEN": exp.Flatten.from_arg_list, 451 "ARRAY_TO_STRING": lambda args: exp.ArrayToString( 452 this=seq_get(args, 0), 453 expression=seq_get(args, 1), 454 null_is_empty=True, 455 null_delim_is_null=True, 456 ), 457 "ARRAYS_OVERLAP": lambda args: exp.ArrayOverlaps( 458 this=seq_get(args, 0), expression=seq_get(args, 1), null_safe=True 459 ), 460 "BITAND": _build_bitwise(exp.BitwiseAnd, "BITAND"), 461 "BIT_AND": _build_bitwise(exp.BitwiseAnd, "BITAND"), 462 "BITNOT": lambda args: exp.BitwiseNot(this=seq_get(args, 0)), 463 "BIT_NOT": lambda args: exp.BitwiseNot(this=seq_get(args, 0)), 464 "BITXOR": _build_bitwise(exp.BitwiseXor, "BITXOR"), 465 "BIT_XOR": _build_bitwise(exp.BitwiseXor, "BITXOR"), 466 "BITOR": _build_bitwise(exp.BitwiseOr, "BITOR"), 467 "BIT_OR": _build_bitwise(exp.BitwiseOr, "BITOR"), 468 "BITSHIFTLEFT": _build_bitwise(exp.BitwiseLeftShift, "BITSHIFTLEFT"), 469 "BIT_SHIFTLEFT": _build_bitwise(exp.BitwiseLeftShift, "BIT_SHIFTLEFT"), 470 "BITSHIFTRIGHT": _build_bitwise(exp.BitwiseRightShift, "BITSHIFTRIGHT"), 471 "BIT_SHIFTRIGHT": _build_bitwise(exp.BitwiseRightShift, "BIT_SHIFTRIGHT"), 472 "BITANDAGG": exp.BitwiseAndAgg.from_arg_list, 473 "BITAND_AGG": exp.BitwiseAndAgg.from_arg_list, 474 "BIT_AND_AGG": exp.BitwiseAndAgg.from_arg_list, 475 "BIT_ANDAGG": exp.BitwiseAndAgg.from_arg_list, 476 "BITORAGG": exp.BitwiseOrAgg.from_arg_list, 477 "BITOR_AGG": exp.BitwiseOrAgg.from_arg_list, 478 "BIT_OR_AGG": exp.BitwiseOrAgg.from_arg_list, 479 "BIT_ORAGG": exp.BitwiseOrAgg.from_arg_list, 480 "BITXORAGG": exp.BitwiseXorAgg.from_arg_list, 481 "BITXOR_AGG": exp.BitwiseXorAgg.from_arg_list, 482 "BIT_XOR_AGG": exp.BitwiseXorAgg.from_arg_list, 483 "BIT_XORAGG": exp.BitwiseXorAgg.from_arg_list, 484 "BITMAP_OR_AGG": exp.BitmapOrAgg.from_arg_list, 485 "BOOLAND": lambda args: exp.Booland( 486 this=seq_get(args, 0), expression=seq_get(args, 1), round_input=True 487 ), 488 "BOOLOR": lambda args: exp.Boolor( 489 this=seq_get(args, 0), expression=seq_get(args, 1), round_input=True 490 ), 491 "BOOLNOT": lambda args: exp.Boolnot(this=seq_get(args, 0), round_input=True), 492 "BOOLXOR": lambda args: exp.Xor( 493 this=seq_get(args, 0), expression=seq_get(args, 1), round_input=True 494 ), 495 "CORR": lambda args: exp.Corr( 496 this=seq_get(args, 0), 497 expression=seq_get(args, 1), 498 null_on_zero_variance=True, 499 ), 500 "DATE": _build_datetime("DATE", exp.DType.DATE), 501 "DATEFROMPARTS": _build_date_from_parts, 502 "DATE_FROM_PARTS": _build_date_from_parts, 503 "DATE_TRUNC": _date_trunc_to_time, 504 "DATEADD": lambda args: exp.DateAdd( 505 this=seq_get(args, 2), 506 expression=seq_get(args, 1), 507 unit=map_date_part(seq_get(args, 0)), 508 ), 509 "DATEDIFF": lambda args: exp.DateDiff( 510 this=seq_get(args, 2), 511 expression=seq_get(args, 1), 512 unit=map_date_part(seq_get(args, 0)), 513 date_part_boundary=True, 514 ), 515 "DAYNAME": lambda args: exp.Dayname(this=seq_get(args, 0), abbreviated=True), 516 "DAYOFWEEKISO": exp.DayOfWeekIso.from_arg_list, 517 "DIV0": _build_if_from_div0, 518 "DIV0NULL": _build_if_from_div0null, 519 "EDITDISTANCE": lambda args: exp.Levenshtein( 520 this=seq_get(args, 0), expression=seq_get(args, 1), max_dist=seq_get(args, 2) 521 ), 522 "FLATTEN": exp.Explode.from_arg_list, 523 "GENERATOR": _build_generator, 524 "GET": exp.GetExtract.from_arg_list, 525 "GETDATE": exp.CurrentTimestamp.from_arg_list, 526 "GET_PATH": lambda args, dialect: exp.JSONExtract( 527 this=seq_get(args, 0), 528 expression=dialect.to_json_path(seq_get(args, 1)), 529 requires_json=True, 530 ), 531 "GREATEST_IGNORE_NULLS": lambda args: exp.Greatest( 532 this=seq_get(args, 0), expressions=args[1:], ignore_nulls=True 533 ), 534 "LEAST_IGNORE_NULLS": lambda args: exp.Least( 535 this=seq_get(args, 0), expressions=args[1:], ignore_nulls=True 536 ), 537 "LEFT": lambda args: exp.Left( 538 this=seq_get(args, 0), expression=seq_get(args, 1), negative_length_returns_empty=True 539 ), 540 "HEX_DECODE_BINARY": exp.Unhex.from_arg_list, 541 "HEX_ENCODE": exp.Hex.from_arg_list, 542 "IFF": exp.If.from_arg_list, 543 "JAROWINKLER_SIMILARITY": lambda args: exp.JarowinklerSimilarity( 544 this=seq_get(args, 0), 545 expression=seq_get(args, 1), 546 case_insensitive=True, 547 integer_scale=True, 548 ), 549 "MD5_HEX": exp.MD5.from_arg_list, 550 "MD5_BINARY": exp.MD5Digest.from_arg_list, 551 "MD5_NUMBER_LOWER64": exp.MD5NumberLower64.from_arg_list, 552 "MD5_NUMBER_UPPER64": exp.MD5NumberUpper64.from_arg_list, 553 "MONTHNAME": lambda args: exp.Monthname(this=seq_get(args, 0), abbreviated=True), 554 "LAST_DAY": lambda args: exp.LastDay( 555 this=seq_get(args, 0), unit=map_date_part(seq_get(args, 1)) 556 ), 557 "LEN": lambda args: exp.Length(this=seq_get(args, 0), binary=True), 558 "LENGTH": lambda args: exp.Length(this=seq_get(args, 0), binary=True), 559 "LOCALTIMESTAMP": exp.CurrentTimestamp.from_arg_list, 560 "NULLIFZERO": _build_if_from_nullifzero, 561 "OBJECT_CONSTRUCT": lambda args: build_object_construct(args), 562 "OBJECT_KEYS": exp.JSONKeys.from_arg_list, 563 "OCTET_LENGTH": exp.ByteLength.from_arg_list, 564 "PARSE_URL": lambda args: exp.ParseUrl(this=seq_get(args, 0), permissive=seq_get(args, 1)), 565 "REGEXP_EXTRACT_ALL": _build_regexp_extract(exp.RegexpExtractAll), 566 "REGEXP_LIKE": _build_regexp_like, 567 "REGEXP_REPLACE": _build_regexp_replace, 568 "REGEXP_SUBSTR": _build_regexp_extract(exp.RegexpExtract), 569 "REGEXP_SUBSTR_ALL": _build_regexp_extract(exp.RegexpExtractAll), 570 "RANDOM": lambda args: exp.Rand( 571 this=seq_get(args, 0), 572 lower=exp.Literal.number(-9223372036854775808.0), # -2^63 as float to avoid overflow 573 upper=exp.Literal.number(9223372036854775807.0), # 2^63-1 as float 574 ), 575 "REPLACE": build_replace_with_optional_replacement, 576 "RIGHT": lambda args: exp.Right( 577 this=seq_get(args, 0), expression=seq_get(args, 1), negative_length_returns_empty=True 578 ), 579 "RLIKE": _build_regexp_like, 580 "ROUND": _build_round, 581 "SHA1_BINARY": exp.SHA1Digest.from_arg_list, 582 "SHA1_HEX": exp.SHA.from_arg_list, 583 "SHA2_BINARY": exp.SHA2Digest.from_arg_list, 584 "SHA2_HEX": exp.SHA2.from_arg_list, 585 "SPLIT": lambda args: exp.Split( 586 this=seq_get(args, 0), 587 expression=seq_get(args, 1), 588 null_returns_null=True, 589 empty_delimiter_returns_whole=True, 590 ), 591 "SQUARE": lambda args: exp.Pow(this=seq_get(args, 0), expression=exp.Literal.number(2)), 592 "STDDEV_SAMP": exp.Stddev.from_arg_list, 593 "SYSDATE": lambda args: exp.CurrentTimestamp(this=seq_get(args, 0), sysdate=True), 594 "TABLE": lambda args: exp.TableFromRows(this=seq_get(args, 0)), 595 "TIMEADD": lambda args: exp.TimeAdd( 596 this=seq_get(args, 2), 597 expression=seq_get(args, 1), 598 unit=map_date_part(seq_get(args, 0)), 599 ), 600 "TIMEDIFF": lambda args: exp.DateDiff( 601 this=seq_get(args, 2), 602 expression=seq_get(args, 1), 603 unit=map_date_part(seq_get(args, 0)), 604 date_part_boundary=True, 605 ), 606 "TIME_FROM_PARTS": lambda args: exp.TimeFromParts( 607 hour=seq_get(args, 0), 608 min=seq_get(args, 1), 609 sec=seq_get(args, 2), 610 nano=seq_get(args, 3), 611 overflow=True, 612 ), 613 "TIMESTAMPADD": lambda args: exp.DateAdd( 614 this=seq_get(args, 2), 615 expression=seq_get(args, 1), 616 unit=map_date_part(seq_get(args, 0)), 617 ), 618 "TIMESTAMPDIFF": lambda args: exp.DateDiff( 619 this=seq_get(args, 2), 620 expression=seq_get(args, 1), 621 unit=map_date_part(seq_get(args, 0)), 622 date_part_boundary=True, 623 ), 624 "TIMESTAMPFROMPARTS": _build_timestamp_from_parts, 625 "TIMESTAMP_FROM_PARTS": _build_timestamp_from_parts, 626 "TIMESTAMPNTZFROMPARTS": _build_timestamp_from_parts, 627 "TIMESTAMP_NTZ_FROM_PARTS": _build_timestamp_from_parts, 628 "TRUNC": lambda args, dialect: build_trunc( 629 args, dialect, date_trunc_requires_part=False, fractions_supported=True 630 ), 631 "TRUNCATE": lambda args, dialect: build_trunc( 632 args, dialect, date_trunc_requires_part=False, fractions_supported=True 633 ), 634 "TRY_DECRYPT": lambda args: exp.Decrypt( 635 this=seq_get(args, 0), 636 passphrase=seq_get(args, 1), 637 aad=seq_get(args, 2), 638 encryption_method=seq_get(args, 3), 639 safe=True, 640 ), 641 "TRY_DECRYPT_RAW": lambda args: exp.DecryptRaw( 642 this=seq_get(args, 0), 643 key=seq_get(args, 1), 644 iv=seq_get(args, 2), 645 aad=seq_get(args, 3), 646 encryption_method=seq_get(args, 4), 647 aead=seq_get(args, 5), 648 safe=True, 649 ), 650 "TRY_PARSE_JSON": lambda args: exp.ParseJSON(this=seq_get(args, 0), safe=True), 651 "TRY_TO_BINARY": lambda args: exp.ToBinary( 652 this=seq_get(args, 0), format=seq_get(args, 1), safe=True 653 ), 654 "TRY_TO_BOOLEAN": lambda args: exp.ToBoolean(this=seq_get(args, 0), safe=True), 655 "TRY_TO_DATE": _build_datetime("TRY_TO_DATE", exp.DType.DATE, safe=True), 656 **dict.fromkeys( 657 ("TRY_TO_DECIMAL", "TRY_TO_NUMBER", "TRY_TO_NUMERIC"), 658 lambda args: _build_to_number(args, safe=True), 659 ), 660 "TRY_TO_DOUBLE": lambda args: exp.ToDouble( 661 this=seq_get(args, 0), format=seq_get(args, 1), safe=True 662 ), 663 "TRY_TO_FILE": lambda args: exp.ToFile( 664 this=seq_get(args, 0), path=seq_get(args, 1), safe=True 665 ), 666 "TRY_TO_TIME": _build_datetime("TRY_TO_TIME", exp.DType.TIME, safe=True), 667 "TRY_TO_TIMESTAMP": _build_datetime("TRY_TO_TIMESTAMP", exp.DType.TIMESTAMP, safe=True), 668 "TRY_TO_TIMESTAMP_LTZ": _build_datetime( 669 "TRY_TO_TIMESTAMP_LTZ", exp.DType.TIMESTAMPLTZ, safe=True 670 ), 671 "TRY_TO_TIMESTAMP_NTZ": _build_datetime( 672 "TRY_TO_TIMESTAMP_NTZ", exp.DType.TIMESTAMPNTZ, safe=True 673 ), 674 "TRY_TO_TIMESTAMP_TZ": _build_datetime( 675 "TRY_TO_TIMESTAMP_TZ", exp.DType.TIMESTAMPTZ, safe=True 676 ), 677 "TO_CHAR": build_timetostr_or_tochar, 678 "TO_DATE": _build_datetime("TO_DATE", exp.DType.DATE), 679 **dict.fromkeys( 680 ("TO_DECIMAL", "TO_NUMBER", "TO_NUMERIC"), 681 lambda args: _build_to_number(args), 682 ), 683 "TO_TIME": _build_datetime("TO_TIME", exp.DType.TIME), 684 "TO_TIMESTAMP": _build_datetime("TO_TIMESTAMP", exp.DType.TIMESTAMP), 685 "TO_TIMESTAMP_LTZ": _build_datetime("TO_TIMESTAMP_LTZ", exp.DType.TIMESTAMPLTZ), 686 "TO_TIMESTAMP_NTZ": _build_datetime("TO_TIMESTAMP_NTZ", exp.DType.TIMESTAMPNTZ), 687 "TO_TIMESTAMP_TZ": _build_datetime("TO_TIMESTAMP_TZ", exp.DType.TIMESTAMPTZ), 688 "TO_GEOGRAPHY": lambda args: ( 689 exp.cast(args[0], exp.DType.GEOGRAPHY) 690 if len(args) == 1 691 else exp.Anonymous(this="TO_GEOGRAPHY", expressions=args) 692 ), 693 "TO_GEOMETRY": lambda args: ( 694 exp.cast(args[0], exp.DType.GEOMETRY) 695 if len(args) == 1 696 else exp.Anonymous(this="TO_GEOMETRY", expressions=args) 697 ), 698 "TO_VARCHAR": build_timetostr_or_tochar, 699 "TO_JSON": exp.JSONFormat.from_arg_list, 700 "VECTOR_COSINE_SIMILARITY": exp.CosineDistance.from_arg_list, 701 "VECTOR_INNER_PRODUCT": exp.DotProduct.from_arg_list, 702 "VECTOR_L1_DISTANCE": exp.ManhattanDistance.from_arg_list, 703 "VECTOR_L2_DISTANCE": exp.EuclideanDistance.from_arg_list, 704 "ZEROIFNULL": _build_if_from_zeroifnull, 705 "LIKE": build_like(exp.Like), 706 "ILIKE": build_like(exp.ILike), 707 "SEARCH": _build_search, 708 "SKEW": exp.Skewness.from_arg_list, 709 "SPLIT_PART": lambda args: exp.SplitPart( 710 this=seq_get(args, 0), 711 delimiter=seq_get(args, 1), 712 part_index=seq_get(args, 2), 713 part_index_zero_as_one=True, 714 empty_delimiter_returns_whole=True, 715 ), 716 "STRTOK": lambda args: exp.Strtok( 717 this=seq_get(args, 0), 718 delimiter=seq_get(args, 1) or exp.Literal.string(" "), 719 part_index=seq_get(args, 2) or exp.Literal.number("1"), 720 ), 721 "STRTOK_TO_ARRAY": lambda args: exp.StrtokToArray( 722 this=seq_get(args, 0), 723 expression=seq_get(args, 1) or exp.Literal.string(" "), 724 ), 725 "SYSTIMESTAMP": exp.CurrentTimestamp.from_arg_list, 726 "UNICODE": lambda args: exp.Unicode(this=seq_get(args, 0), empty_is_zero=True), 727 "WEEKISO": exp.WeekOfYear.from_arg_list, 728 "WEEKOFYEAR": exp.Week.from_arg_list, 729 } 730 FUNCTIONS = {k: v for k, v in FUNCTIONS.items() if k != "PREDICT"} 731 732 FUNCTION_PARSERS = { 733 **parser.Parser.FUNCTION_PARSERS, 734 "DATE_PART": lambda self: self._parse_date_part(), 735 "DIRECTORY": lambda self: self._parse_directory(), 736 "OBJECT_CONSTRUCT_KEEP_NULL": lambda self: self._parse_json_object(), 737 "LISTAGG": lambda self: self._parse_string_agg(), 738 "SEMANTIC_VIEW": lambda self: self._parse_semantic_view(), 739 "SUBSTR": lambda self: self._parse_substring(), 740 } 741 FUNCTION_PARSERS = {k: v for k, v in FUNCTION_PARSERS.items() if k != "TRIM"} 742 743 TIMESTAMPS = parser.Parser.TIMESTAMPS - {TokenType.TIME} 744 745 ALTER_PARSERS = { 746 **parser.Parser.ALTER_PARSERS, 747 "MODIFY": lambda self: self._parse_alter_table_alter(), 748 "SESSION": lambda self: self._parse_alter_session(), 749 "UNSET": lambda self: self.expression( 750 exp.Set( 751 tag=self._match_text_seq("TAG"), 752 expressions=self._parse_csv(self._parse_id_var), 753 unset=True, 754 ) 755 ), 756 } 757 758 STATEMENT_PARSERS = { 759 **parser.Parser.STATEMENT_PARSERS, 760 TokenType.GET: lambda self: self._parse_get(), 761 TokenType.PUT: lambda self: self._parse_put(), 762 TokenType.SHOW: lambda self: self._parse_show(), 763 } 764 765 PROPERTY_PARSERS = { 766 **parser.Parser.PROPERTY_PARSERS, 767 "CREDENTIALS": lambda self: self._parse_credentials_property(), 768 "FILE_FORMAT": lambda self: self._parse_file_format_property(), 769 "LOCATION": lambda self: self._parse_location_property(), 770 "ROW": lambda self: ( 771 self._parse_row_access_policy() 772 if self._match_text_seq("ACCESS", "POLICY") 773 else self._parse_row() 774 ), 775 "TAG": lambda self: self._parse_tag(), 776 "USING": lambda self: ( 777 self._match_text_seq("TEMPLATE") 778 and self.expression(exp.UsingTemplateProperty(this=self._parse_statement())) 779 ), 780 } 781 782 DESCRIBE_QUALIFIER_PARSERS: t.ClassVar[dict[str, t.Callable]] = { 783 "API": lambda self: self.expression(exp.ApiProperty()), 784 "APPLICATION": lambda self: self.expression(exp.ApplicationProperty()), 785 "CATALOG": lambda self: self.expression(exp.CatalogProperty()), 786 "COMPUTE": lambda self: self.expression(exp.ComputeProperty()), 787 "DATABASE": lambda self: ( 788 self.expression(exp.DatabaseProperty()) 789 if self._curr and self._curr.text.upper() == "ROLE" 790 else None 791 ), 792 "DYNAMIC": lambda self: self.expression(exp.DynamicProperty()), 793 "EXTERNAL": lambda self: self.expression(exp.ExternalProperty()), 794 "HYBRID": lambda self: self.expression(exp.HybridProperty()), 795 "ICEBERG": lambda self: self.expression(exp.IcebergProperty()), 796 "MASKING": lambda self: self.expression(exp.MaskingProperty()), 797 "MATERIALIZED": lambda self: self.expression(exp.MaterializedProperty()), 798 "NETWORK": lambda self: self.expression(exp.NetworkProperty()), 799 "ROW": lambda self: ( 800 self.expression(exp.RowAccessProperty()) if self._match_text_seq("ACCESS") else None 801 ), 802 "SECURITY": lambda self: ( 803 self.expression(exp.SecurityIntegrationProperty()) 804 if self._curr and self._curr.text.upper() == "INTEGRATION" 805 else None 806 ), 807 } 808 809 TYPE_CONVERTERS = { 810 # https://docs.snowflake.com/en/sql-reference/data-types-numeric#number 811 exp.DType.DECIMAL: build_default_decimal_type(precision=38, scale=0), 812 } 813 814 SHOW_PARSERS = { 815 "DATABASES": _show_parser("DATABASES"), 816 "SCHEMAS": _show_parser("SCHEMAS"), 817 "OBJECTS": _show_parser("OBJECTS"), 818 "TABLES": _show_parser("TABLES"), 819 "VIEWS": _show_parser("VIEWS"), 820 "PRIMARY KEYS": _show_parser("PRIMARY KEYS"), 821 "IMPORTED KEYS": _show_parser("IMPORTED KEYS"), 822 "UNIQUE KEYS": _show_parser("UNIQUE KEYS"), 823 "SEQUENCES": _show_parser("SEQUENCES"), 824 "STAGES": _show_parser("STAGES"), 825 "COLUMNS": _show_parser("COLUMNS"), 826 "USERS": _show_parser("USERS"), 827 "FILE FORMATS": _show_parser("FILE FORMATS"), 828 "FUNCTIONS": _show_parser("FUNCTIONS"), 829 "PROCEDURES": _show_parser("PROCEDURES"), 830 "WAREHOUSES": _show_parser("WAREHOUSES"), 831 "ICEBERG TABLES": _show_parser("TABLES", iceberg=True), 832 "TERSE ICEBERG TABLES": _show_parser("TABLES", terse=True, iceberg=True), 833 "TERSE DATABASES": _show_parser("DATABASES", terse=True), 834 "TERSE SCHEMAS": _show_parser("SCHEMAS", terse=True), 835 "TERSE OBJECTS": _show_parser("OBJECTS", terse=True), 836 "TERSE TABLES": _show_parser("TABLES", terse=True), 837 "TERSE VIEWS": _show_parser("VIEWS", terse=True), 838 "TERSE SEQUENCES": _show_parser("SEQUENCES", terse=True), 839 "TERSE USERS": _show_parser("USERS", terse=True), 840 # TERSE has no semantic effect for KEYS, so we do not set the terse AST arg 841 "TERSE PRIMARY KEYS": _show_parser("PRIMARY KEYS"), 842 "TERSE IMPORTED KEYS": _show_parser("IMPORTED KEYS"), 843 "TERSE UNIQUE KEYS": _show_parser("UNIQUE KEYS"), 844 } 845 846 SHOW_TRIE = new_trie(key.split(" ") for key in SHOW_PARSERS) 847 848 CONSTRAINT_PARSERS = { 849 **parser.Parser.CONSTRAINT_PARSERS, 850 "WITH": lambda self: self._parse_with_constraint(), 851 "MASKING": lambda self: self._parse_with_constraint(), 852 "PROJECTION": lambda self: self._parse_with_constraint(), 853 "TAG": lambda self: self._parse_with_constraint(), 854 } 855 856 STAGED_FILE_SINGLE_TOKENS = { 857 TokenType.DOT, 858 TokenType.MOD, 859 TokenType.SLASH, 860 } 861 862 FLATTEN_COLUMNS = ["SEQ", "KEY", "PATH", "INDEX", "VALUE", "THIS"] 863 864 SCHEMA_KINDS = {"OBJECTS", "TABLES", "VIEWS", "SEQUENCES", "UNIQUE KEYS", "IMPORTED KEYS"} 865 866 NON_TABLE_CREATABLES = {"STORAGE INTEGRATION", "TAG", "WAREHOUSE", "STREAMLIT"} 867 868 CREATABLES = { 869 *parser.Parser.CREATABLES, 870 TokenType.INTEGRATION, 871 TokenType.PACKAGE, 872 TokenType.POLICY, 873 TokenType.POOL, 874 TokenType.ROLE, 875 TokenType.RULE, 876 TokenType.VOLUME, 877 } 878 879 LAMBDAS = { 880 **parser.Parser.LAMBDAS, 881 TokenType.ARROW: lambda self, expressions: self.expression( 882 exp.Lambda( 883 this=self._replace_lambda( 884 self._parse_assignment(), 885 expressions, 886 ), 887 expressions=[e.this if isinstance(e, exp.Cast) else e for e in expressions], 888 ) 889 ), 890 } 891 892 COLUMN_OPERATORS = { 893 **parser.Parser.COLUMN_OPERATORS, 894 TokenType.EXCLAMATION: lambda self, this, attr: self.expression( 895 exp.ModelAttribute(this=this, expression=attr) 896 ), 897 } 898 899 def _parse_directory(self) -> exp.DirectoryStage: 900 table = self._parse_table_parts() 901 this = table.this if isinstance(table, exp.Table) else table 902 return self.expression(exp.DirectoryStage(this=this)) 903 904 def _parse_describe(self) -> exp.Describe: 905 index = self._index 906 907 if self._match_texts(self.DESCRIBE_QUALIFIER_PARSERS): 908 qualifier = self.DESCRIBE_QUALIFIER_PARSERS[self._prev.text.upper()](self) 909 910 if qualifier: 911 kind = self._match_set(self.CREATABLES) and self._prev.text.upper() 912 913 if kind: 914 this = self._parse_table(schema=True) 915 properties = self.expression(exp.Properties(expressions=[qualifier])) 916 post_props = self._parse_properties() 917 expressions = post_props.expressions if post_props else None 918 return self.expression( 919 exp.Describe( 920 this=this, 921 kind=kind, 922 properties=properties, 923 expressions=expressions, 924 ) 925 ) 926 927 self._retreat(index) 928 return super()._parse_describe() 929 930 def _parse_use(self) -> exp.Use: 931 if self._match_text_seq("SECONDARY", "ROLES"): 932 this = self._match_texts(("ALL", "NONE")) and exp.var(self._prev.text.upper()) 933 roles = None if this else self._parse_csv(lambda: self._parse_table(schema=False)) 934 return self.expression(exp.Use(kind="SECONDARY ROLES", this=this, expressions=roles)) 935 936 return super()._parse_use() 937 938 def _negate_range(self, this: exp.Expr | None = None) -> exp.Expr | None: 939 if not this: 940 return this 941 942 query = this.args.get("query") 943 if isinstance(this, exp.In) and isinstance(query, exp.Query): 944 # Snowflake treats `value NOT IN (subquery)` as `VALUE <> ALL (subquery)`, so 945 # we do this conversion here to avoid parsing it into `NOT value IN (subquery)` 946 # which can produce different results (most likely a SnowFlake bug). 947 # 948 # https://docs.snowflake.com/en/sql-reference/functions/in 949 # Context: https://github.com/tobymao/sqlglot/issues/3890 950 return self.expression(exp.NEQ(this=this.this, expression=exp.All(this=query.unnest()))) 951 952 return self.expression(exp.Not(this=this)) 953 954 def _parse_tag(self) -> exp.Tags: 955 return self.expression(exp.Tags(expressions=self._parse_wrapped_csv(self._parse_property))) 956 957 def _parse_with_constraint(self) -> exp.Expr | None: 958 if self._prev.token_type != TokenType.WITH: 959 self._retreat(self._index - 1) 960 961 if self._match_text_seq("MASKING", "POLICY"): 962 policy = self._parse_column() 963 return self.expression( 964 exp.MaskingPolicyColumnConstraint( 965 this=policy.to_dot() if isinstance(policy, exp.Column) else policy, 966 expressions=self._match(TokenType.USING) 967 and self._parse_wrapped_csv(self._parse_id_var), 968 ) 969 ) 970 if self._match_text_seq("PROJECTION", "POLICY"): 971 policy = self._parse_column() 972 return self.expression( 973 exp.ProjectionPolicyColumnConstraint( 974 this=policy.to_dot() if isinstance(policy, exp.Column) else policy 975 ) 976 ) 977 if self._match(TokenType.TAG): 978 return self._parse_tag() 979 980 return None 981 982 def _parse_with_property(self) -> exp.Expr | None | list[exp.Expr]: 983 if self._match(TokenType.TAG): 984 return self._parse_tag() 985 986 if self._match_text_seq("ROW", "ACCESS", "POLICY"): 987 return self._parse_row_access_policy() 988 989 return super()._parse_with_property() 990 991 def _parse_row_access_policy(self) -> exp.RowAccessProperty: 992 # GET_DDL outputs #unknown_policy when the user lacks privileges to see the policy name 993 if self._match(TokenType.HASH): 994 policy: exp.Expr | None = self._parse_var(any_token=True) 995 if policy: 996 policy = exp.Var(this=f"#{policy.name}") 997 expressions = None 998 else: 999 policy = self._parse_column() 1000 if isinstance(policy, exp.Column): 1001 policy = policy.to_dot() 1002 if not self._match(TokenType.ON): 1003 self.raise_error("Expected ON after ROW ACCESS POLICY name") 1004 expressions = self._parse_wrapped_csv(self._parse_id_var) 1005 1006 return self.expression(exp.RowAccessProperty(this=policy, expressions=expressions)) 1007 1008 def _parse_create(self) -> exp.Create | exp.Command: 1009 expression = super()._parse_create() 1010 if isinstance(expression, exp.Create) and expression.kind in self.NON_TABLE_CREATABLES: 1011 # Replace the Table node with the enclosed Identifier 1012 expression.this.replace(expression.this.this) 1013 1014 return expression 1015 1016 # https://docs.snowflake.com/en/sql-reference/functions/date_part.html 1017 # https://docs.snowflake.com/en/sql-reference/functions-date-time.html#label-supported-date-time-parts 1018 def _parse_date_part(self) -> exp.Expr | None: 1019 this = self._parse_var() or self._parse_type() 1020 1021 if not this: 1022 return None 1023 1024 # Handle both syntaxes: DATE_PART(part, expr) and DATE_PART(part FROM expr) 1025 expression = self._match_set((TokenType.FROM, TokenType.COMMA)) and self._parse_bitwise() 1026 return self.expression( 1027 exp.Extract(this=map_date_part(this, self.dialect), expression=expression) 1028 ) 1029 1030 def _parse_bracket_key_value(self, is_map: bool = False) -> exp.Expr | None: 1031 if is_map: 1032 # Keys are strings in Snowflake's objects, see also: 1033 # - https://docs.snowflake.com/en/sql-reference/data-types-semistructured 1034 # - https://docs.snowflake.com/en/sql-reference/functions/object_construct 1035 return self._parse_slice(self._parse_string()) or self._parse_assignment() 1036 1037 return self._parse_slice(self._parse_alias(self._parse_assignment(), explicit=True)) 1038 1039 def _parse_lateral(self) -> exp.Lateral | None: 1040 lateral = super()._parse_lateral() 1041 if not lateral: 1042 return lateral 1043 1044 if isinstance(lateral.this, exp.Explode): 1045 table_alias = lateral.args.get("alias") 1046 columns = [exp.to_identifier(col) for col in self.FLATTEN_COLUMNS] 1047 if table_alias and not table_alias.args.get("columns"): 1048 table_alias.set("columns", columns) 1049 elif not table_alias: 1050 exp.alias_(lateral, "_flattened", table=columns, copy=False) 1051 1052 return lateral 1053 1054 def _parse_table_parts( 1055 self, 1056 schema: bool = False, 1057 is_db_reference: bool = False, 1058 wildcard: bool = False, 1059 fast: bool = False, 1060 ) -> exp.Table | exp.Dot | None: 1061 # https://docs.snowflake.com/en/user-guide/querying-stage 1062 if self._match(TokenType.STRING, advance=False): 1063 table = self._parse_string() 1064 elif self._match_text_seq("@", advance=False): 1065 table = self._parse_location_path() 1066 else: 1067 table = None 1068 1069 if table: 1070 file_format = None 1071 pattern = None 1072 1073 wrapped = self._match(TokenType.L_PAREN) 1074 while self._curr and wrapped and not self._match(TokenType.R_PAREN): 1075 if self._match_text_seq("FILE_FORMAT", "=>"): 1076 file_format = self._parse_string() or super()._parse_table_parts( 1077 is_db_reference=is_db_reference 1078 ) 1079 elif self._match_text_seq("PATTERN", "=>"): 1080 pattern = self._parse_string() 1081 else: 1082 break 1083 1084 self._match(TokenType.COMMA) 1085 1086 table = self.expression(exp.Table(this=table, format=file_format, pattern=pattern)) 1087 else: 1088 table = super()._parse_table_parts( 1089 schema=schema, 1090 is_db_reference=is_db_reference, 1091 fast=fast, 1092 ) 1093 1094 return table 1095 1096 def _parse_table( 1097 self, 1098 schema: bool = False, 1099 joins: bool = False, 1100 alias_tokens: Collection[TokenType] | None = None, 1101 parse_bracket: bool = False, 1102 is_db_reference: bool = False, 1103 parse_partition: bool = False, 1104 consume_pipe: bool = False, 1105 ) -> exp.Expr | None: 1106 table = super()._parse_table( 1107 schema=schema, 1108 joins=joins, 1109 alias_tokens=alias_tokens, 1110 parse_bracket=parse_bracket, 1111 is_db_reference=is_db_reference, 1112 parse_partition=parse_partition, 1113 ) 1114 if isinstance(table, exp.Table) and isinstance(table.this, exp.TableFromRows): 1115 table_from_rows = table.this 1116 for arg in exp.TableFromRows.arg_types: 1117 if arg != "this": 1118 table_from_rows.set(arg, table.args.get(arg)) 1119 1120 table = table_from_rows 1121 1122 return table 1123 1124 def _parse_id_var( 1125 self, 1126 any_token: bool = True, 1127 tokens: Collection[TokenType] | None = None, 1128 ) -> exp.Expr | None: 1129 if self._match_text_seq("IDENTIFIER", "("): 1130 identifier = ( 1131 super()._parse_id_var(any_token=any_token, tokens=tokens) or self._parse_string() 1132 ) 1133 self._match_r_paren() 1134 return self.expression(exp.Anonymous(this="IDENTIFIER", expressions=[identifier])) 1135 1136 return super()._parse_id_var(any_token=any_token, tokens=tokens) 1137 1138 def _parse_show_snowflake( 1139 self, this: str, terse: bool = False, iceberg: bool = False 1140 ) -> exp.Show: 1141 scope = None 1142 scope_kind = None 1143 1144 history = self._match_text_seq("HISTORY") 1145 1146 like = self._parse_string() if self._match(TokenType.LIKE) else None 1147 1148 if self._match(TokenType.IN): 1149 if self._match_text_seq("ACCOUNT"): 1150 scope_kind = "ACCOUNT" 1151 elif self._match_text_seq("CLASS"): 1152 scope_kind = "CLASS" 1153 scope = self._parse_table_parts() 1154 elif self._match_text_seq("APPLICATION"): 1155 scope_kind = "APPLICATION" 1156 if self._match_text_seq("PACKAGE"): 1157 scope_kind += " PACKAGE" 1158 scope = self._parse_table_parts() 1159 elif self._match_set(self.DB_CREATABLES): 1160 scope_kind = self._prev.text.upper() 1161 if self._curr: 1162 scope = self._parse_table_parts() 1163 elif self._curr: 1164 scope_kind = "SCHEMA" if this in self.SCHEMA_KINDS else "TABLE" 1165 scope = self._parse_table_parts() 1166 1167 return self.expression( 1168 exp.Show( 1169 terse=terse, 1170 iceberg=iceberg, 1171 this=this, 1172 history=history, 1173 like=like, 1174 scope=scope, 1175 scope_kind=scope_kind, 1176 starts_with=self._match_text_seq("STARTS", "WITH") and self._parse_string(), 1177 limit=self._parse_limit(), 1178 from_=self._parse_string() if self._match(TokenType.FROM) else None, 1179 privileges=self._match_text_seq("WITH", "PRIVILEGES") 1180 and self._parse_csv(lambda: self._parse_var(any_token=True, upper=True)), 1181 ) 1182 ) 1183 1184 def _parse_put(self) -> exp.Put | exp.Command: 1185 if self._curr.token_type != TokenType.STRING: 1186 return self._parse_as_command(self._prev) 1187 1188 return self.expression( 1189 exp.Put( 1190 this=self._parse_string(), 1191 target=self._parse_location_path(), 1192 properties=self._parse_properties(), 1193 ) 1194 ) 1195 1196 def _parse_get(self) -> exp.Expr | None: 1197 start = self._prev 1198 1199 # If we detect GET( then we need to parse a function, not a statement 1200 if self._match(TokenType.L_PAREN): 1201 self._retreat(self._index - 2) 1202 return self._parse_expression() 1203 1204 target = self._parse_location_path() 1205 1206 # Parse as command if unquoted file path 1207 if self._curr.token_type == TokenType.URI_START: 1208 return self._parse_as_command(start) 1209 1210 return self.expression( 1211 exp.Get(this=self._parse_string(), target=target, properties=self._parse_properties()) 1212 ) 1213 1214 def _parse_location_property(self) -> exp.LocationProperty: 1215 self._match(TokenType.EQ) 1216 return self.expression(exp.LocationProperty(this=self._parse_location_path())) 1217 1218 def _parse_file_location(self) -> exp.Expr | None: 1219 # Parse either a subquery or a staged file 1220 return ( 1221 self._parse_select(table=True, parse_subquery_alias=False) 1222 if self._match(TokenType.L_PAREN, advance=False) 1223 else self._parse_table_parts() 1224 ) 1225 1226 def _parse_location_path(self) -> exp.Var: 1227 start = self._curr 1228 self._advance_any(ignore_reserved=True) 1229 1230 # We avoid consuming a comma token because external tables like @foo and @bar 1231 # can be joined in a query with a comma separator, as well as closing paren 1232 # in case of subqueries 1233 while self._is_connected() and not self._match_set( 1234 (TokenType.COMMA, TokenType.L_PAREN, TokenType.R_PAREN), advance=False 1235 ): 1236 self._advance_any(ignore_reserved=True) 1237 1238 return exp.var(self._find_sql(start, self._prev)) 1239 1240 def _parse_lambda_arg(self) -> exp.Expr | None: 1241 this = super()._parse_lambda_arg() 1242 1243 if not this: 1244 return this 1245 1246 typ = self._parse_types() 1247 1248 if typ: 1249 return self.expression(exp.Cast(this=this, to=typ)) 1250 1251 return this 1252 1253 def _parse_foreign_key(self) -> exp.ForeignKey: 1254 # inlineFK, the REFERENCES columns are implied 1255 if self._match(TokenType.REFERENCES, advance=False): 1256 return self.expression(exp.ForeignKey()) 1257 1258 # outoflineFK, explicitly names the columns 1259 return super()._parse_foreign_key() 1260 1261 def _parse_file_format_property(self) -> exp.FileFormatProperty: 1262 self._match(TokenType.EQ) 1263 if self._match(TokenType.L_PAREN, advance=False): 1264 expressions = self._parse_wrapped_options() 1265 else: 1266 expressions = [self._parse_format_name()] 1267 1268 return self.expression(exp.FileFormatProperty(expressions=expressions)) 1269 1270 def _parse_credentials_property(self) -> exp.CredentialsProperty: 1271 return self.expression(exp.CredentialsProperty(expressions=self._parse_wrapped_options())) 1272 1273 def _parse_semantic_view(self) -> exp.SemanticView: 1274 kwargs: dict[str, t.Any] = {"this": self._parse_table_parts()} 1275 1276 while self._curr and not self._match(TokenType.R_PAREN, advance=False): 1277 if self._match_texts(("DIMENSIONS", "METRICS", "FACTS")): 1278 keyword = self._prev.text.lower() 1279 kwargs[keyword] = self._parse_csv( 1280 lambda: self._parse_alias(self._parse_disjunction(), explicit=True) 1281 ) 1282 elif self._match_text_seq("WHERE"): 1283 kwargs["where"] = self._parse_expression() 1284 else: 1285 self.raise_error("Expecting ) or encountered unexpected keyword") 1286 break 1287 1288 return self.expression(exp.SemanticView(**kwargs)) 1289 1290 def _parse_set(self, unset: bool = False, tag: bool = False) -> exp.Set | exp.Command: 1291 set = super()._parse_set(unset=unset, tag=tag) 1292 1293 if isinstance(set, exp.Set): 1294 for expr in set.expressions: 1295 if isinstance(expr, exp.SetItem): 1296 expr.set("kind", "VARIABLE") 1297 return set 1298 1299 def _parse_position(self, haystack_first: bool = False) -> exp.StrPosition: 1300 result = super()._parse_position(haystack_first) 1301 result.set("clamp_position", True) 1302 return result 1303 1304 def _parse_substring(self) -> exp.Substring: 1305 result = super()._parse_substring() 1306 result.set("zero_start", True) 1307 return result 1308 1309 def build_cast(self, strict: bool, **kwargs) -> exp.Expr: 1310 to = kwargs.get("to") 1311 if not strict and to and to.this == exp.DataType.Type.BOOLEAN: 1312 return self.expression(exp.ToBoolean(this=kwargs.get("this"), safe=True)) 1313 cast = super().build_cast(strict, **kwargs) 1314 if isinstance(cast, exp.TryCast) and to: 1315 if to.this in exp.DataType.TEXT_TYPES and to.expressions: 1316 cast.set("null_on_text_overflow", True) 1317 elif to.this == exp.DType.DATE and cast.this.is_string: 1318 cast.set("probe_date_format", True) 1319 return cast 1320 1321 def _parse_window(self, this: exp.Expr | None, alias: bool = False) -> exp.Expr | None: 1322 if isinstance(this, exp.NthValue): 1323 if self._match_text_seq("FROM"): 1324 if self._match_texts(("FIRST", "LAST")): 1325 from_first = self._prev.text.upper() == "FIRST" 1326 this.set("from_first", from_first) 1327 1328 result = super()._parse_window(this, alias) 1329 1330 # Set default window frame for ranking functions if not present 1331 if ( 1332 isinstance(result, exp.Window) 1333 and isinstance(this, RANKING_WINDOW_FUNCTIONS_WITH_FRAME) 1334 and not result.args.get("spec") 1335 ): 1336 frame = exp.WindowSpec( 1337 kind="ROWS", 1338 start="UNBOUNDED", 1339 start_side="PRECEDING", 1340 end="UNBOUNDED", 1341 end_side="FOLLOWING", 1342 ) 1343 result.set("spec", frame) 1344 return result 1345 1346 1347# This is imported and used by both the parser (above) and the generator in the dialect file 1348RANKING_WINDOW_FUNCTIONS_WITH_FRAME = ( 1349 exp.FirstValue, 1350 exp.LastValue, 1351 exp.NthValue, 1352) 1353 1354 1355def build_object_construct(args: list) -> exp.StarMap | exp.Struct: 1356 expression = parser.build_var_map(args) 1357 1358 if isinstance(expression, exp.StarMap): 1359 return expression 1360 1361 return exp.Struct( 1362 expressions=[ 1363 exp.PropertyEQ(this=k, expression=v) for k, v in zip(expression.keys, expression.values) 1364 ] 1365 )
TIMESTAMP_TYPES =
{<DType.TIMESTAMP: 'TIMESTAMP'>: 'TO_TIMESTAMP', <DType.TIMESTAMPLTZ: 'TIMESTAMPLTZ'>: 'TO_TIMESTAMP_LTZ', <DType.TIMESTAMPNTZ: 'TIMESTAMPNTZ'>: 'TO_TIMESTAMP_NTZ', <DType.TIMESTAMPTZ: 'TIMESTAMPTZ'>: 'TO_TIMESTAMP_TZ'}
330class SnowflakeParser(parser.Parser): 331 IDENTIFY_PIVOT_STRINGS = True 332 TYPED_LAMBDA_ARGS = True 333 DEFAULT_SAMPLING_METHOD = "BERNOULLI" 334 COLON_IS_VARIANT_EXTRACT = True 335 JSON_EXTRACT_REQUIRES_JSON_EXPRESSION = True 336 337 TYPE_TOKENS = {*parser.Parser.TYPE_TOKENS, TokenType.FILE} 338 STRUCT_TYPE_TOKENS = {*parser.Parser.STRUCT_TYPE_TOKENS, TokenType.FILE} 339 NESTED_TYPE_TOKENS = {*parser.Parser.NESTED_TYPE_TOKENS, TokenType.FILE} 340 341 ID_VAR_TOKENS = { 342 *parser.Parser.ID_VAR_TOKENS, 343 TokenType.EXCEPT, 344 TokenType.INTEGRATION, 345 TokenType.MATCH_CONDITION, 346 TokenType.PACKAGE, 347 TokenType.POLICY, 348 TokenType.POOL, 349 TokenType.ROLE, 350 TokenType.RULE, 351 TokenType.VOLUME, 352 } 353 354 ALIAS_TOKENS = parser.Parser.ALIAS_TOKENS | { 355 TokenType.INTEGRATION, 356 TokenType.PACKAGE, 357 TokenType.POLICY, 358 TokenType.POOL, 359 TokenType.ROLE, 360 TokenType.RULE, 361 TokenType.VOLUME, 362 } 363 364 TABLE_ALIAS_TOKENS = ( 365 parser.Parser.TABLE_ALIAS_TOKENS 366 | { 367 TokenType.ANTI, 368 TokenType.INTEGRATION, 369 TokenType.PACKAGE, 370 TokenType.POLICY, 371 TokenType.POOL, 372 TokenType.ROLE, 373 TokenType.RULE, 374 TokenType.SEMI, 375 TokenType.VOLUME, 376 TokenType.WINDOW, 377 } 378 ) - {TokenType.MATCH_CONDITION} 379 380 COLON_PLACEHOLDER_TOKENS = ID_VAR_TOKENS | {TokenType.NUMBER} 381 382 NO_PAREN_FUNCTIONS = { 383 **parser.Parser.NO_PAREN_FUNCTIONS, 384 TokenType.LOCALTIME: exp.Localtime, 385 TokenType.LOCALTIMESTAMP: exp.Localtimestamp, 386 TokenType.CURRENT_TIME: exp.Localtime, 387 } 388 389 RANGE_PARSERS = { 390 **parser.Parser.RANGE_PARSERS, 391 TokenType.RLIKE: lambda self, this: self.expression( 392 exp.RegexpLike(this=this, expression=self._parse_bitwise(), full_match=True) 393 ), 394 } 395 396 FUNCTIONS = { 397 **parser.Parser.FUNCTIONS, 398 "CHARINDEX": lambda args: exp.StrPosition( 399 this=seq_get(args, 1), 400 substr=seq_get(args, 0), 401 position=seq_get(args, 2), 402 clamp_position=True, 403 ), 404 "ADD_MONTHS": lambda args: exp.AddMonths( 405 this=seq_get(args, 0), 406 expression=seq_get(args, 1), 407 preserve_end_of_month=True, 408 ), 409 "APPROX_PERCENTILE": exp.ApproxQuantile.from_arg_list, 410 "CURRENT_TIME": lambda args: exp.Localtime(this=seq_get(args, 0)), 411 "APPROX_TOP_K": _build_approx_top_k, 412 "ARRAY_CONSTRUCT": lambda args: exp.Array(expressions=args), 413 "ARRAY_CONTAINS": lambda args: exp.ArrayContains( 414 this=seq_get(args, 1), 415 expression=seq_get(args, 0), 416 ensure_variant=False, 417 check_null=True, 418 ), 419 "ARRAY_DISTINCT": lambda args: exp.ArrayDistinct( 420 this=seq_get(args, 0), 421 check_null=True, 422 ), 423 "ARRAY_GENERATE_RANGE": lambda args: exp.GenerateSeries( 424 # Snowflake has exclusive end semantics 425 start=seq_get(args, 0), 426 end=seq_get(args, 1), 427 step=seq_get(args, 2), 428 is_end_exclusive=True, 429 ), 430 "ARRAY_EXCEPT": lambda args: exp.ArrayExcept( 431 this=seq_get(args, 0), 432 expression=seq_get(args, 1), 433 is_multiset=True, 434 ), 435 "ARRAY_INTERSECTION": lambda args: exp.ArrayIntersect( 436 expressions=args, 437 is_multiset=True, 438 ), 439 "ARRAY_POSITION": lambda args: exp.ArrayPosition( 440 this=seq_get(args, 1), 441 expression=seq_get(args, 0), 442 zero_based=True, 443 ), 444 "ARRAY_SLICE": lambda args: exp.ArraySlice( 445 this=seq_get(args, 0), 446 start=seq_get(args, 1), 447 end=seq_get(args, 2), 448 zero_based=True, 449 ), 450 "ARRAY_SORT": _build_array_sort, 451 "ARRAY_FLATTEN": exp.Flatten.from_arg_list, 452 "ARRAY_TO_STRING": lambda args: exp.ArrayToString( 453 this=seq_get(args, 0), 454 expression=seq_get(args, 1), 455 null_is_empty=True, 456 null_delim_is_null=True, 457 ), 458 "ARRAYS_OVERLAP": lambda args: exp.ArrayOverlaps( 459 this=seq_get(args, 0), expression=seq_get(args, 1), null_safe=True 460 ), 461 "BITAND": _build_bitwise(exp.BitwiseAnd, "BITAND"), 462 "BIT_AND": _build_bitwise(exp.BitwiseAnd, "BITAND"), 463 "BITNOT": lambda args: exp.BitwiseNot(this=seq_get(args, 0)), 464 "BIT_NOT": lambda args: exp.BitwiseNot(this=seq_get(args, 0)), 465 "BITXOR": _build_bitwise(exp.BitwiseXor, "BITXOR"), 466 "BIT_XOR": _build_bitwise(exp.BitwiseXor, "BITXOR"), 467 "BITOR": _build_bitwise(exp.BitwiseOr, "BITOR"), 468 "BIT_OR": _build_bitwise(exp.BitwiseOr, "BITOR"), 469 "BITSHIFTLEFT": _build_bitwise(exp.BitwiseLeftShift, "BITSHIFTLEFT"), 470 "BIT_SHIFTLEFT": _build_bitwise(exp.BitwiseLeftShift, "BIT_SHIFTLEFT"), 471 "BITSHIFTRIGHT": _build_bitwise(exp.BitwiseRightShift, "BITSHIFTRIGHT"), 472 "BIT_SHIFTRIGHT": _build_bitwise(exp.BitwiseRightShift, "BIT_SHIFTRIGHT"), 473 "BITANDAGG": exp.BitwiseAndAgg.from_arg_list, 474 "BITAND_AGG": exp.BitwiseAndAgg.from_arg_list, 475 "BIT_AND_AGG": exp.BitwiseAndAgg.from_arg_list, 476 "BIT_ANDAGG": exp.BitwiseAndAgg.from_arg_list, 477 "BITORAGG": exp.BitwiseOrAgg.from_arg_list, 478 "BITOR_AGG": exp.BitwiseOrAgg.from_arg_list, 479 "BIT_OR_AGG": exp.BitwiseOrAgg.from_arg_list, 480 "BIT_ORAGG": exp.BitwiseOrAgg.from_arg_list, 481 "BITXORAGG": exp.BitwiseXorAgg.from_arg_list, 482 "BITXOR_AGG": exp.BitwiseXorAgg.from_arg_list, 483 "BIT_XOR_AGG": exp.BitwiseXorAgg.from_arg_list, 484 "BIT_XORAGG": exp.BitwiseXorAgg.from_arg_list, 485 "BITMAP_OR_AGG": exp.BitmapOrAgg.from_arg_list, 486 "BOOLAND": lambda args: exp.Booland( 487 this=seq_get(args, 0), expression=seq_get(args, 1), round_input=True 488 ), 489 "BOOLOR": lambda args: exp.Boolor( 490 this=seq_get(args, 0), expression=seq_get(args, 1), round_input=True 491 ), 492 "BOOLNOT": lambda args: exp.Boolnot(this=seq_get(args, 0), round_input=True), 493 "BOOLXOR": lambda args: exp.Xor( 494 this=seq_get(args, 0), expression=seq_get(args, 1), round_input=True 495 ), 496 "CORR": lambda args: exp.Corr( 497 this=seq_get(args, 0), 498 expression=seq_get(args, 1), 499 null_on_zero_variance=True, 500 ), 501 "DATE": _build_datetime("DATE", exp.DType.DATE), 502 "DATEFROMPARTS": _build_date_from_parts, 503 "DATE_FROM_PARTS": _build_date_from_parts, 504 "DATE_TRUNC": _date_trunc_to_time, 505 "DATEADD": lambda args: exp.DateAdd( 506 this=seq_get(args, 2), 507 expression=seq_get(args, 1), 508 unit=map_date_part(seq_get(args, 0)), 509 ), 510 "DATEDIFF": lambda args: exp.DateDiff( 511 this=seq_get(args, 2), 512 expression=seq_get(args, 1), 513 unit=map_date_part(seq_get(args, 0)), 514 date_part_boundary=True, 515 ), 516 "DAYNAME": lambda args: exp.Dayname(this=seq_get(args, 0), abbreviated=True), 517 "DAYOFWEEKISO": exp.DayOfWeekIso.from_arg_list, 518 "DIV0": _build_if_from_div0, 519 "DIV0NULL": _build_if_from_div0null, 520 "EDITDISTANCE": lambda args: exp.Levenshtein( 521 this=seq_get(args, 0), expression=seq_get(args, 1), max_dist=seq_get(args, 2) 522 ), 523 "FLATTEN": exp.Explode.from_arg_list, 524 "GENERATOR": _build_generator, 525 "GET": exp.GetExtract.from_arg_list, 526 "GETDATE": exp.CurrentTimestamp.from_arg_list, 527 "GET_PATH": lambda args, dialect: exp.JSONExtract( 528 this=seq_get(args, 0), 529 expression=dialect.to_json_path(seq_get(args, 1)), 530 requires_json=True, 531 ), 532 "GREATEST_IGNORE_NULLS": lambda args: exp.Greatest( 533 this=seq_get(args, 0), expressions=args[1:], ignore_nulls=True 534 ), 535 "LEAST_IGNORE_NULLS": lambda args: exp.Least( 536 this=seq_get(args, 0), expressions=args[1:], ignore_nulls=True 537 ), 538 "LEFT": lambda args: exp.Left( 539 this=seq_get(args, 0), expression=seq_get(args, 1), negative_length_returns_empty=True 540 ), 541 "HEX_DECODE_BINARY": exp.Unhex.from_arg_list, 542 "HEX_ENCODE": exp.Hex.from_arg_list, 543 "IFF": exp.If.from_arg_list, 544 "JAROWINKLER_SIMILARITY": lambda args: exp.JarowinklerSimilarity( 545 this=seq_get(args, 0), 546 expression=seq_get(args, 1), 547 case_insensitive=True, 548 integer_scale=True, 549 ), 550 "MD5_HEX": exp.MD5.from_arg_list, 551 "MD5_BINARY": exp.MD5Digest.from_arg_list, 552 "MD5_NUMBER_LOWER64": exp.MD5NumberLower64.from_arg_list, 553 "MD5_NUMBER_UPPER64": exp.MD5NumberUpper64.from_arg_list, 554 "MONTHNAME": lambda args: exp.Monthname(this=seq_get(args, 0), abbreviated=True), 555 "LAST_DAY": lambda args: exp.LastDay( 556 this=seq_get(args, 0), unit=map_date_part(seq_get(args, 1)) 557 ), 558 "LEN": lambda args: exp.Length(this=seq_get(args, 0), binary=True), 559 "LENGTH": lambda args: exp.Length(this=seq_get(args, 0), binary=True), 560 "LOCALTIMESTAMP": exp.CurrentTimestamp.from_arg_list, 561 "NULLIFZERO": _build_if_from_nullifzero, 562 "OBJECT_CONSTRUCT": lambda args: build_object_construct(args), 563 "OBJECT_KEYS": exp.JSONKeys.from_arg_list, 564 "OCTET_LENGTH": exp.ByteLength.from_arg_list, 565 "PARSE_URL": lambda args: exp.ParseUrl(this=seq_get(args, 0), permissive=seq_get(args, 1)), 566 "REGEXP_EXTRACT_ALL": _build_regexp_extract(exp.RegexpExtractAll), 567 "REGEXP_LIKE": _build_regexp_like, 568 "REGEXP_REPLACE": _build_regexp_replace, 569 "REGEXP_SUBSTR": _build_regexp_extract(exp.RegexpExtract), 570 "REGEXP_SUBSTR_ALL": _build_regexp_extract(exp.RegexpExtractAll), 571 "RANDOM": lambda args: exp.Rand( 572 this=seq_get(args, 0), 573 lower=exp.Literal.number(-9223372036854775808.0), # -2^63 as float to avoid overflow 574 upper=exp.Literal.number(9223372036854775807.0), # 2^63-1 as float 575 ), 576 "REPLACE": build_replace_with_optional_replacement, 577 "RIGHT": lambda args: exp.Right( 578 this=seq_get(args, 0), expression=seq_get(args, 1), negative_length_returns_empty=True 579 ), 580 "RLIKE": _build_regexp_like, 581 "ROUND": _build_round, 582 "SHA1_BINARY": exp.SHA1Digest.from_arg_list, 583 "SHA1_HEX": exp.SHA.from_arg_list, 584 "SHA2_BINARY": exp.SHA2Digest.from_arg_list, 585 "SHA2_HEX": exp.SHA2.from_arg_list, 586 "SPLIT": lambda args: exp.Split( 587 this=seq_get(args, 0), 588 expression=seq_get(args, 1), 589 null_returns_null=True, 590 empty_delimiter_returns_whole=True, 591 ), 592 "SQUARE": lambda args: exp.Pow(this=seq_get(args, 0), expression=exp.Literal.number(2)), 593 "STDDEV_SAMP": exp.Stddev.from_arg_list, 594 "SYSDATE": lambda args: exp.CurrentTimestamp(this=seq_get(args, 0), sysdate=True), 595 "TABLE": lambda args: exp.TableFromRows(this=seq_get(args, 0)), 596 "TIMEADD": lambda args: exp.TimeAdd( 597 this=seq_get(args, 2), 598 expression=seq_get(args, 1), 599 unit=map_date_part(seq_get(args, 0)), 600 ), 601 "TIMEDIFF": lambda args: exp.DateDiff( 602 this=seq_get(args, 2), 603 expression=seq_get(args, 1), 604 unit=map_date_part(seq_get(args, 0)), 605 date_part_boundary=True, 606 ), 607 "TIME_FROM_PARTS": lambda args: exp.TimeFromParts( 608 hour=seq_get(args, 0), 609 min=seq_get(args, 1), 610 sec=seq_get(args, 2), 611 nano=seq_get(args, 3), 612 overflow=True, 613 ), 614 "TIMESTAMPADD": lambda args: exp.DateAdd( 615 this=seq_get(args, 2), 616 expression=seq_get(args, 1), 617 unit=map_date_part(seq_get(args, 0)), 618 ), 619 "TIMESTAMPDIFF": lambda args: exp.DateDiff( 620 this=seq_get(args, 2), 621 expression=seq_get(args, 1), 622 unit=map_date_part(seq_get(args, 0)), 623 date_part_boundary=True, 624 ), 625 "TIMESTAMPFROMPARTS": _build_timestamp_from_parts, 626 "TIMESTAMP_FROM_PARTS": _build_timestamp_from_parts, 627 "TIMESTAMPNTZFROMPARTS": _build_timestamp_from_parts, 628 "TIMESTAMP_NTZ_FROM_PARTS": _build_timestamp_from_parts, 629 "TRUNC": lambda args, dialect: build_trunc( 630 args, dialect, date_trunc_requires_part=False, fractions_supported=True 631 ), 632 "TRUNCATE": lambda args, dialect: build_trunc( 633 args, dialect, date_trunc_requires_part=False, fractions_supported=True 634 ), 635 "TRY_DECRYPT": lambda args: exp.Decrypt( 636 this=seq_get(args, 0), 637 passphrase=seq_get(args, 1), 638 aad=seq_get(args, 2), 639 encryption_method=seq_get(args, 3), 640 safe=True, 641 ), 642 "TRY_DECRYPT_RAW": lambda args: exp.DecryptRaw( 643 this=seq_get(args, 0), 644 key=seq_get(args, 1), 645 iv=seq_get(args, 2), 646 aad=seq_get(args, 3), 647 encryption_method=seq_get(args, 4), 648 aead=seq_get(args, 5), 649 safe=True, 650 ), 651 "TRY_PARSE_JSON": lambda args: exp.ParseJSON(this=seq_get(args, 0), safe=True), 652 "TRY_TO_BINARY": lambda args: exp.ToBinary( 653 this=seq_get(args, 0), format=seq_get(args, 1), safe=True 654 ), 655 "TRY_TO_BOOLEAN": lambda args: exp.ToBoolean(this=seq_get(args, 0), safe=True), 656 "TRY_TO_DATE": _build_datetime("TRY_TO_DATE", exp.DType.DATE, safe=True), 657 **dict.fromkeys( 658 ("TRY_TO_DECIMAL", "TRY_TO_NUMBER", "TRY_TO_NUMERIC"), 659 lambda args: _build_to_number(args, safe=True), 660 ), 661 "TRY_TO_DOUBLE": lambda args: exp.ToDouble( 662 this=seq_get(args, 0), format=seq_get(args, 1), safe=True 663 ), 664 "TRY_TO_FILE": lambda args: exp.ToFile( 665 this=seq_get(args, 0), path=seq_get(args, 1), safe=True 666 ), 667 "TRY_TO_TIME": _build_datetime("TRY_TO_TIME", exp.DType.TIME, safe=True), 668 "TRY_TO_TIMESTAMP": _build_datetime("TRY_TO_TIMESTAMP", exp.DType.TIMESTAMP, safe=True), 669 "TRY_TO_TIMESTAMP_LTZ": _build_datetime( 670 "TRY_TO_TIMESTAMP_LTZ", exp.DType.TIMESTAMPLTZ, safe=True 671 ), 672 "TRY_TO_TIMESTAMP_NTZ": _build_datetime( 673 "TRY_TO_TIMESTAMP_NTZ", exp.DType.TIMESTAMPNTZ, safe=True 674 ), 675 "TRY_TO_TIMESTAMP_TZ": _build_datetime( 676 "TRY_TO_TIMESTAMP_TZ", exp.DType.TIMESTAMPTZ, safe=True 677 ), 678 "TO_CHAR": build_timetostr_or_tochar, 679 "TO_DATE": _build_datetime("TO_DATE", exp.DType.DATE), 680 **dict.fromkeys( 681 ("TO_DECIMAL", "TO_NUMBER", "TO_NUMERIC"), 682 lambda args: _build_to_number(args), 683 ), 684 "TO_TIME": _build_datetime("TO_TIME", exp.DType.TIME), 685 "TO_TIMESTAMP": _build_datetime("TO_TIMESTAMP", exp.DType.TIMESTAMP), 686 "TO_TIMESTAMP_LTZ": _build_datetime("TO_TIMESTAMP_LTZ", exp.DType.TIMESTAMPLTZ), 687 "TO_TIMESTAMP_NTZ": _build_datetime("TO_TIMESTAMP_NTZ", exp.DType.TIMESTAMPNTZ), 688 "TO_TIMESTAMP_TZ": _build_datetime("TO_TIMESTAMP_TZ", exp.DType.TIMESTAMPTZ), 689 "TO_GEOGRAPHY": lambda args: ( 690 exp.cast(args[0], exp.DType.GEOGRAPHY) 691 if len(args) == 1 692 else exp.Anonymous(this="TO_GEOGRAPHY", expressions=args) 693 ), 694 "TO_GEOMETRY": lambda args: ( 695 exp.cast(args[0], exp.DType.GEOMETRY) 696 if len(args) == 1 697 else exp.Anonymous(this="TO_GEOMETRY", expressions=args) 698 ), 699 "TO_VARCHAR": build_timetostr_or_tochar, 700 "TO_JSON": exp.JSONFormat.from_arg_list, 701 "VECTOR_COSINE_SIMILARITY": exp.CosineDistance.from_arg_list, 702 "VECTOR_INNER_PRODUCT": exp.DotProduct.from_arg_list, 703 "VECTOR_L1_DISTANCE": exp.ManhattanDistance.from_arg_list, 704 "VECTOR_L2_DISTANCE": exp.EuclideanDistance.from_arg_list, 705 "ZEROIFNULL": _build_if_from_zeroifnull, 706 "LIKE": build_like(exp.Like), 707 "ILIKE": build_like(exp.ILike), 708 "SEARCH": _build_search, 709 "SKEW": exp.Skewness.from_arg_list, 710 "SPLIT_PART": lambda args: exp.SplitPart( 711 this=seq_get(args, 0), 712 delimiter=seq_get(args, 1), 713 part_index=seq_get(args, 2), 714 part_index_zero_as_one=True, 715 empty_delimiter_returns_whole=True, 716 ), 717 "STRTOK": lambda args: exp.Strtok( 718 this=seq_get(args, 0), 719 delimiter=seq_get(args, 1) or exp.Literal.string(" "), 720 part_index=seq_get(args, 2) or exp.Literal.number("1"), 721 ), 722 "STRTOK_TO_ARRAY": lambda args: exp.StrtokToArray( 723 this=seq_get(args, 0), 724 expression=seq_get(args, 1) or exp.Literal.string(" "), 725 ), 726 "SYSTIMESTAMP": exp.CurrentTimestamp.from_arg_list, 727 "UNICODE": lambda args: exp.Unicode(this=seq_get(args, 0), empty_is_zero=True), 728 "WEEKISO": exp.WeekOfYear.from_arg_list, 729 "WEEKOFYEAR": exp.Week.from_arg_list, 730 } 731 FUNCTIONS = {k: v for k, v in FUNCTIONS.items() if k != "PREDICT"} 732 733 FUNCTION_PARSERS = { 734 **parser.Parser.FUNCTION_PARSERS, 735 "DATE_PART": lambda self: self._parse_date_part(), 736 "DIRECTORY": lambda self: self._parse_directory(), 737 "OBJECT_CONSTRUCT_KEEP_NULL": lambda self: self._parse_json_object(), 738 "LISTAGG": lambda self: self._parse_string_agg(), 739 "SEMANTIC_VIEW": lambda self: self._parse_semantic_view(), 740 "SUBSTR": lambda self: self._parse_substring(), 741 } 742 FUNCTION_PARSERS = {k: v for k, v in FUNCTION_PARSERS.items() if k != "TRIM"} 743 744 TIMESTAMPS = parser.Parser.TIMESTAMPS - {TokenType.TIME} 745 746 ALTER_PARSERS = { 747 **parser.Parser.ALTER_PARSERS, 748 "MODIFY": lambda self: self._parse_alter_table_alter(), 749 "SESSION": lambda self: self._parse_alter_session(), 750 "UNSET": lambda self: self.expression( 751 exp.Set( 752 tag=self._match_text_seq("TAG"), 753 expressions=self._parse_csv(self._parse_id_var), 754 unset=True, 755 ) 756 ), 757 } 758 759 STATEMENT_PARSERS = { 760 **parser.Parser.STATEMENT_PARSERS, 761 TokenType.GET: lambda self: self._parse_get(), 762 TokenType.PUT: lambda self: self._parse_put(), 763 TokenType.SHOW: lambda self: self._parse_show(), 764 } 765 766 PROPERTY_PARSERS = { 767 **parser.Parser.PROPERTY_PARSERS, 768 "CREDENTIALS": lambda self: self._parse_credentials_property(), 769 "FILE_FORMAT": lambda self: self._parse_file_format_property(), 770 "LOCATION": lambda self: self._parse_location_property(), 771 "ROW": lambda self: ( 772 self._parse_row_access_policy() 773 if self._match_text_seq("ACCESS", "POLICY") 774 else self._parse_row() 775 ), 776 "TAG": lambda self: self._parse_tag(), 777 "USING": lambda self: ( 778 self._match_text_seq("TEMPLATE") 779 and self.expression(exp.UsingTemplateProperty(this=self._parse_statement())) 780 ), 781 } 782 783 DESCRIBE_QUALIFIER_PARSERS: t.ClassVar[dict[str, t.Callable]] = { 784 "API": lambda self: self.expression(exp.ApiProperty()), 785 "APPLICATION": lambda self: self.expression(exp.ApplicationProperty()), 786 "CATALOG": lambda self: self.expression(exp.CatalogProperty()), 787 "COMPUTE": lambda self: self.expression(exp.ComputeProperty()), 788 "DATABASE": lambda self: ( 789 self.expression(exp.DatabaseProperty()) 790 if self._curr and self._curr.text.upper() == "ROLE" 791 else None 792 ), 793 "DYNAMIC": lambda self: self.expression(exp.DynamicProperty()), 794 "EXTERNAL": lambda self: self.expression(exp.ExternalProperty()), 795 "HYBRID": lambda self: self.expression(exp.HybridProperty()), 796 "ICEBERG": lambda self: self.expression(exp.IcebergProperty()), 797 "MASKING": lambda self: self.expression(exp.MaskingProperty()), 798 "MATERIALIZED": lambda self: self.expression(exp.MaterializedProperty()), 799 "NETWORK": lambda self: self.expression(exp.NetworkProperty()), 800 "ROW": lambda self: ( 801 self.expression(exp.RowAccessProperty()) if self._match_text_seq("ACCESS") else None 802 ), 803 "SECURITY": lambda self: ( 804 self.expression(exp.SecurityIntegrationProperty()) 805 if self._curr and self._curr.text.upper() == "INTEGRATION" 806 else None 807 ), 808 } 809 810 TYPE_CONVERTERS = { 811 # https://docs.snowflake.com/en/sql-reference/data-types-numeric#number 812 exp.DType.DECIMAL: build_default_decimal_type(precision=38, scale=0), 813 } 814 815 SHOW_PARSERS = { 816 "DATABASES": _show_parser("DATABASES"), 817 "SCHEMAS": _show_parser("SCHEMAS"), 818 "OBJECTS": _show_parser("OBJECTS"), 819 "TABLES": _show_parser("TABLES"), 820 "VIEWS": _show_parser("VIEWS"), 821 "PRIMARY KEYS": _show_parser("PRIMARY KEYS"), 822 "IMPORTED KEYS": _show_parser("IMPORTED KEYS"), 823 "UNIQUE KEYS": _show_parser("UNIQUE KEYS"), 824 "SEQUENCES": _show_parser("SEQUENCES"), 825 "STAGES": _show_parser("STAGES"), 826 "COLUMNS": _show_parser("COLUMNS"), 827 "USERS": _show_parser("USERS"), 828 "FILE FORMATS": _show_parser("FILE FORMATS"), 829 "FUNCTIONS": _show_parser("FUNCTIONS"), 830 "PROCEDURES": _show_parser("PROCEDURES"), 831 "WAREHOUSES": _show_parser("WAREHOUSES"), 832 "ICEBERG TABLES": _show_parser("TABLES", iceberg=True), 833 "TERSE ICEBERG TABLES": _show_parser("TABLES", terse=True, iceberg=True), 834 "TERSE DATABASES": _show_parser("DATABASES", terse=True), 835 "TERSE SCHEMAS": _show_parser("SCHEMAS", terse=True), 836 "TERSE OBJECTS": _show_parser("OBJECTS", terse=True), 837 "TERSE TABLES": _show_parser("TABLES", terse=True), 838 "TERSE VIEWS": _show_parser("VIEWS", terse=True), 839 "TERSE SEQUENCES": _show_parser("SEQUENCES", terse=True), 840 "TERSE USERS": _show_parser("USERS", terse=True), 841 # TERSE has no semantic effect for KEYS, so we do not set the terse AST arg 842 "TERSE PRIMARY KEYS": _show_parser("PRIMARY KEYS"), 843 "TERSE IMPORTED KEYS": _show_parser("IMPORTED KEYS"), 844 "TERSE UNIQUE KEYS": _show_parser("UNIQUE KEYS"), 845 } 846 847 SHOW_TRIE = new_trie(key.split(" ") for key in SHOW_PARSERS) 848 849 CONSTRAINT_PARSERS = { 850 **parser.Parser.CONSTRAINT_PARSERS, 851 "WITH": lambda self: self._parse_with_constraint(), 852 "MASKING": lambda self: self._parse_with_constraint(), 853 "PROJECTION": lambda self: self._parse_with_constraint(), 854 "TAG": lambda self: self._parse_with_constraint(), 855 } 856 857 STAGED_FILE_SINGLE_TOKENS = { 858 TokenType.DOT, 859 TokenType.MOD, 860 TokenType.SLASH, 861 } 862 863 FLATTEN_COLUMNS = ["SEQ", "KEY", "PATH", "INDEX", "VALUE", "THIS"] 864 865 SCHEMA_KINDS = {"OBJECTS", "TABLES", "VIEWS", "SEQUENCES", "UNIQUE KEYS", "IMPORTED KEYS"} 866 867 NON_TABLE_CREATABLES = {"STORAGE INTEGRATION", "TAG", "WAREHOUSE", "STREAMLIT"} 868 869 CREATABLES = { 870 *parser.Parser.CREATABLES, 871 TokenType.INTEGRATION, 872 TokenType.PACKAGE, 873 TokenType.POLICY, 874 TokenType.POOL, 875 TokenType.ROLE, 876 TokenType.RULE, 877 TokenType.VOLUME, 878 } 879 880 LAMBDAS = { 881 **parser.Parser.LAMBDAS, 882 TokenType.ARROW: lambda self, expressions: self.expression( 883 exp.Lambda( 884 this=self._replace_lambda( 885 self._parse_assignment(), 886 expressions, 887 ), 888 expressions=[e.this if isinstance(e, exp.Cast) else e for e in expressions], 889 ) 890 ), 891 } 892 893 COLUMN_OPERATORS = { 894 **parser.Parser.COLUMN_OPERATORS, 895 TokenType.EXCLAMATION: lambda self, this, attr: self.expression( 896 exp.ModelAttribute(this=this, expression=attr) 897 ), 898 } 899 900 def _parse_directory(self) -> exp.DirectoryStage: 901 table = self._parse_table_parts() 902 this = table.this if isinstance(table, exp.Table) else table 903 return self.expression(exp.DirectoryStage(this=this)) 904 905 def _parse_describe(self) -> exp.Describe: 906 index = self._index 907 908 if self._match_texts(self.DESCRIBE_QUALIFIER_PARSERS): 909 qualifier = self.DESCRIBE_QUALIFIER_PARSERS[self._prev.text.upper()](self) 910 911 if qualifier: 912 kind = self._match_set(self.CREATABLES) and self._prev.text.upper() 913 914 if kind: 915 this = self._parse_table(schema=True) 916 properties = self.expression(exp.Properties(expressions=[qualifier])) 917 post_props = self._parse_properties() 918 expressions = post_props.expressions if post_props else None 919 return self.expression( 920 exp.Describe( 921 this=this, 922 kind=kind, 923 properties=properties, 924 expressions=expressions, 925 ) 926 ) 927 928 self._retreat(index) 929 return super()._parse_describe() 930 931 def _parse_use(self) -> exp.Use: 932 if self._match_text_seq("SECONDARY", "ROLES"): 933 this = self._match_texts(("ALL", "NONE")) and exp.var(self._prev.text.upper()) 934 roles = None if this else self._parse_csv(lambda: self._parse_table(schema=False)) 935 return self.expression(exp.Use(kind="SECONDARY ROLES", this=this, expressions=roles)) 936 937 return super()._parse_use() 938 939 def _negate_range(self, this: exp.Expr | None = None) -> exp.Expr | None: 940 if not this: 941 return this 942 943 query = this.args.get("query") 944 if isinstance(this, exp.In) and isinstance(query, exp.Query): 945 # Snowflake treats `value NOT IN (subquery)` as `VALUE <> ALL (subquery)`, so 946 # we do this conversion here to avoid parsing it into `NOT value IN (subquery)` 947 # which can produce different results (most likely a SnowFlake bug). 948 # 949 # https://docs.snowflake.com/en/sql-reference/functions/in 950 # Context: https://github.com/tobymao/sqlglot/issues/3890 951 return self.expression(exp.NEQ(this=this.this, expression=exp.All(this=query.unnest()))) 952 953 return self.expression(exp.Not(this=this)) 954 955 def _parse_tag(self) -> exp.Tags: 956 return self.expression(exp.Tags(expressions=self._parse_wrapped_csv(self._parse_property))) 957 958 def _parse_with_constraint(self) -> exp.Expr | None: 959 if self._prev.token_type != TokenType.WITH: 960 self._retreat(self._index - 1) 961 962 if self._match_text_seq("MASKING", "POLICY"): 963 policy = self._parse_column() 964 return self.expression( 965 exp.MaskingPolicyColumnConstraint( 966 this=policy.to_dot() if isinstance(policy, exp.Column) else policy, 967 expressions=self._match(TokenType.USING) 968 and self._parse_wrapped_csv(self._parse_id_var), 969 ) 970 ) 971 if self._match_text_seq("PROJECTION", "POLICY"): 972 policy = self._parse_column() 973 return self.expression( 974 exp.ProjectionPolicyColumnConstraint( 975 this=policy.to_dot() if isinstance(policy, exp.Column) else policy 976 ) 977 ) 978 if self._match(TokenType.TAG): 979 return self._parse_tag() 980 981 return None 982 983 def _parse_with_property(self) -> exp.Expr | None | list[exp.Expr]: 984 if self._match(TokenType.TAG): 985 return self._parse_tag() 986 987 if self._match_text_seq("ROW", "ACCESS", "POLICY"): 988 return self._parse_row_access_policy() 989 990 return super()._parse_with_property() 991 992 def _parse_row_access_policy(self) -> exp.RowAccessProperty: 993 # GET_DDL outputs #unknown_policy when the user lacks privileges to see the policy name 994 if self._match(TokenType.HASH): 995 policy: exp.Expr | None = self._parse_var(any_token=True) 996 if policy: 997 policy = exp.Var(this=f"#{policy.name}") 998 expressions = None 999 else: 1000 policy = self._parse_column() 1001 if isinstance(policy, exp.Column): 1002 policy = policy.to_dot() 1003 if not self._match(TokenType.ON): 1004 self.raise_error("Expected ON after ROW ACCESS POLICY name") 1005 expressions = self._parse_wrapped_csv(self._parse_id_var) 1006 1007 return self.expression(exp.RowAccessProperty(this=policy, expressions=expressions)) 1008 1009 def _parse_create(self) -> exp.Create | exp.Command: 1010 expression = super()._parse_create() 1011 if isinstance(expression, exp.Create) and expression.kind in self.NON_TABLE_CREATABLES: 1012 # Replace the Table node with the enclosed Identifier 1013 expression.this.replace(expression.this.this) 1014 1015 return expression 1016 1017 # https://docs.snowflake.com/en/sql-reference/functions/date_part.html 1018 # https://docs.snowflake.com/en/sql-reference/functions-date-time.html#label-supported-date-time-parts 1019 def _parse_date_part(self) -> exp.Expr | None: 1020 this = self._parse_var() or self._parse_type() 1021 1022 if not this: 1023 return None 1024 1025 # Handle both syntaxes: DATE_PART(part, expr) and DATE_PART(part FROM expr) 1026 expression = self._match_set((TokenType.FROM, TokenType.COMMA)) and self._parse_bitwise() 1027 return self.expression( 1028 exp.Extract(this=map_date_part(this, self.dialect), expression=expression) 1029 ) 1030 1031 def _parse_bracket_key_value(self, is_map: bool = False) -> exp.Expr | None: 1032 if is_map: 1033 # Keys are strings in Snowflake's objects, see also: 1034 # - https://docs.snowflake.com/en/sql-reference/data-types-semistructured 1035 # - https://docs.snowflake.com/en/sql-reference/functions/object_construct 1036 return self._parse_slice(self._parse_string()) or self._parse_assignment() 1037 1038 return self._parse_slice(self._parse_alias(self._parse_assignment(), explicit=True)) 1039 1040 def _parse_lateral(self) -> exp.Lateral | None: 1041 lateral = super()._parse_lateral() 1042 if not lateral: 1043 return lateral 1044 1045 if isinstance(lateral.this, exp.Explode): 1046 table_alias = lateral.args.get("alias") 1047 columns = [exp.to_identifier(col) for col in self.FLATTEN_COLUMNS] 1048 if table_alias and not table_alias.args.get("columns"): 1049 table_alias.set("columns", columns) 1050 elif not table_alias: 1051 exp.alias_(lateral, "_flattened", table=columns, copy=False) 1052 1053 return lateral 1054 1055 def _parse_table_parts( 1056 self, 1057 schema: bool = False, 1058 is_db_reference: bool = False, 1059 wildcard: bool = False, 1060 fast: bool = False, 1061 ) -> exp.Table | exp.Dot | None: 1062 # https://docs.snowflake.com/en/user-guide/querying-stage 1063 if self._match(TokenType.STRING, advance=False): 1064 table = self._parse_string() 1065 elif self._match_text_seq("@", advance=False): 1066 table = self._parse_location_path() 1067 else: 1068 table = None 1069 1070 if table: 1071 file_format = None 1072 pattern = None 1073 1074 wrapped = self._match(TokenType.L_PAREN) 1075 while self._curr and wrapped and not self._match(TokenType.R_PAREN): 1076 if self._match_text_seq("FILE_FORMAT", "=>"): 1077 file_format = self._parse_string() or super()._parse_table_parts( 1078 is_db_reference=is_db_reference 1079 ) 1080 elif self._match_text_seq("PATTERN", "=>"): 1081 pattern = self._parse_string() 1082 else: 1083 break 1084 1085 self._match(TokenType.COMMA) 1086 1087 table = self.expression(exp.Table(this=table, format=file_format, pattern=pattern)) 1088 else: 1089 table = super()._parse_table_parts( 1090 schema=schema, 1091 is_db_reference=is_db_reference, 1092 fast=fast, 1093 ) 1094 1095 return table 1096 1097 def _parse_table( 1098 self, 1099 schema: bool = False, 1100 joins: bool = False, 1101 alias_tokens: Collection[TokenType] | None = None, 1102 parse_bracket: bool = False, 1103 is_db_reference: bool = False, 1104 parse_partition: bool = False, 1105 consume_pipe: bool = False, 1106 ) -> exp.Expr | None: 1107 table = super()._parse_table( 1108 schema=schema, 1109 joins=joins, 1110 alias_tokens=alias_tokens, 1111 parse_bracket=parse_bracket, 1112 is_db_reference=is_db_reference, 1113 parse_partition=parse_partition, 1114 ) 1115 if isinstance(table, exp.Table) and isinstance(table.this, exp.TableFromRows): 1116 table_from_rows = table.this 1117 for arg in exp.TableFromRows.arg_types: 1118 if arg != "this": 1119 table_from_rows.set(arg, table.args.get(arg)) 1120 1121 table = table_from_rows 1122 1123 return table 1124 1125 def _parse_id_var( 1126 self, 1127 any_token: bool = True, 1128 tokens: Collection[TokenType] | None = None, 1129 ) -> exp.Expr | None: 1130 if self._match_text_seq("IDENTIFIER", "("): 1131 identifier = ( 1132 super()._parse_id_var(any_token=any_token, tokens=tokens) or self._parse_string() 1133 ) 1134 self._match_r_paren() 1135 return self.expression(exp.Anonymous(this="IDENTIFIER", expressions=[identifier])) 1136 1137 return super()._parse_id_var(any_token=any_token, tokens=tokens) 1138 1139 def _parse_show_snowflake( 1140 self, this: str, terse: bool = False, iceberg: bool = False 1141 ) -> exp.Show: 1142 scope = None 1143 scope_kind = None 1144 1145 history = self._match_text_seq("HISTORY") 1146 1147 like = self._parse_string() if self._match(TokenType.LIKE) else None 1148 1149 if self._match(TokenType.IN): 1150 if self._match_text_seq("ACCOUNT"): 1151 scope_kind = "ACCOUNT" 1152 elif self._match_text_seq("CLASS"): 1153 scope_kind = "CLASS" 1154 scope = self._parse_table_parts() 1155 elif self._match_text_seq("APPLICATION"): 1156 scope_kind = "APPLICATION" 1157 if self._match_text_seq("PACKAGE"): 1158 scope_kind += " PACKAGE" 1159 scope = self._parse_table_parts() 1160 elif self._match_set(self.DB_CREATABLES): 1161 scope_kind = self._prev.text.upper() 1162 if self._curr: 1163 scope = self._parse_table_parts() 1164 elif self._curr: 1165 scope_kind = "SCHEMA" if this in self.SCHEMA_KINDS else "TABLE" 1166 scope = self._parse_table_parts() 1167 1168 return self.expression( 1169 exp.Show( 1170 terse=terse, 1171 iceberg=iceberg, 1172 this=this, 1173 history=history, 1174 like=like, 1175 scope=scope, 1176 scope_kind=scope_kind, 1177 starts_with=self._match_text_seq("STARTS", "WITH") and self._parse_string(), 1178 limit=self._parse_limit(), 1179 from_=self._parse_string() if self._match(TokenType.FROM) else None, 1180 privileges=self._match_text_seq("WITH", "PRIVILEGES") 1181 and self._parse_csv(lambda: self._parse_var(any_token=True, upper=True)), 1182 ) 1183 ) 1184 1185 def _parse_put(self) -> exp.Put | exp.Command: 1186 if self._curr.token_type != TokenType.STRING: 1187 return self._parse_as_command(self._prev) 1188 1189 return self.expression( 1190 exp.Put( 1191 this=self._parse_string(), 1192 target=self._parse_location_path(), 1193 properties=self._parse_properties(), 1194 ) 1195 ) 1196 1197 def _parse_get(self) -> exp.Expr | None: 1198 start = self._prev 1199 1200 # If we detect GET( then we need to parse a function, not a statement 1201 if self._match(TokenType.L_PAREN): 1202 self._retreat(self._index - 2) 1203 return self._parse_expression() 1204 1205 target = self._parse_location_path() 1206 1207 # Parse as command if unquoted file path 1208 if self._curr.token_type == TokenType.URI_START: 1209 return self._parse_as_command(start) 1210 1211 return self.expression( 1212 exp.Get(this=self._parse_string(), target=target, properties=self._parse_properties()) 1213 ) 1214 1215 def _parse_location_property(self) -> exp.LocationProperty: 1216 self._match(TokenType.EQ) 1217 return self.expression(exp.LocationProperty(this=self._parse_location_path())) 1218 1219 def _parse_file_location(self) -> exp.Expr | None: 1220 # Parse either a subquery or a staged file 1221 return ( 1222 self._parse_select(table=True, parse_subquery_alias=False) 1223 if self._match(TokenType.L_PAREN, advance=False) 1224 else self._parse_table_parts() 1225 ) 1226 1227 def _parse_location_path(self) -> exp.Var: 1228 start = self._curr 1229 self._advance_any(ignore_reserved=True) 1230 1231 # We avoid consuming a comma token because external tables like @foo and @bar 1232 # can be joined in a query with a comma separator, as well as closing paren 1233 # in case of subqueries 1234 while self._is_connected() and not self._match_set( 1235 (TokenType.COMMA, TokenType.L_PAREN, TokenType.R_PAREN), advance=False 1236 ): 1237 self._advance_any(ignore_reserved=True) 1238 1239 return exp.var(self._find_sql(start, self._prev)) 1240 1241 def _parse_lambda_arg(self) -> exp.Expr | None: 1242 this = super()._parse_lambda_arg() 1243 1244 if not this: 1245 return this 1246 1247 typ = self._parse_types() 1248 1249 if typ: 1250 return self.expression(exp.Cast(this=this, to=typ)) 1251 1252 return this 1253 1254 def _parse_foreign_key(self) -> exp.ForeignKey: 1255 # inlineFK, the REFERENCES columns are implied 1256 if self._match(TokenType.REFERENCES, advance=False): 1257 return self.expression(exp.ForeignKey()) 1258 1259 # outoflineFK, explicitly names the columns 1260 return super()._parse_foreign_key() 1261 1262 def _parse_file_format_property(self) -> exp.FileFormatProperty: 1263 self._match(TokenType.EQ) 1264 if self._match(TokenType.L_PAREN, advance=False): 1265 expressions = self._parse_wrapped_options() 1266 else: 1267 expressions = [self._parse_format_name()] 1268 1269 return self.expression(exp.FileFormatProperty(expressions=expressions)) 1270 1271 def _parse_credentials_property(self) -> exp.CredentialsProperty: 1272 return self.expression(exp.CredentialsProperty(expressions=self._parse_wrapped_options())) 1273 1274 def _parse_semantic_view(self) -> exp.SemanticView: 1275 kwargs: dict[str, t.Any] = {"this": self._parse_table_parts()} 1276 1277 while self._curr and not self._match(TokenType.R_PAREN, advance=False): 1278 if self._match_texts(("DIMENSIONS", "METRICS", "FACTS")): 1279 keyword = self._prev.text.lower() 1280 kwargs[keyword] = self._parse_csv( 1281 lambda: self._parse_alias(self._parse_disjunction(), explicit=True) 1282 ) 1283 elif self._match_text_seq("WHERE"): 1284 kwargs["where"] = self._parse_expression() 1285 else: 1286 self.raise_error("Expecting ) or encountered unexpected keyword") 1287 break 1288 1289 return self.expression(exp.SemanticView(**kwargs)) 1290 1291 def _parse_set(self, unset: bool = False, tag: bool = False) -> exp.Set | exp.Command: 1292 set = super()._parse_set(unset=unset, tag=tag) 1293 1294 if isinstance(set, exp.Set): 1295 for expr in set.expressions: 1296 if isinstance(expr, exp.SetItem): 1297 expr.set("kind", "VARIABLE") 1298 return set 1299 1300 def _parse_position(self, haystack_first: bool = False) -> exp.StrPosition: 1301 result = super()._parse_position(haystack_first) 1302 result.set("clamp_position", True) 1303 return result 1304 1305 def _parse_substring(self) -> exp.Substring: 1306 result = super()._parse_substring() 1307 result.set("zero_start", True) 1308 return result 1309 1310 def build_cast(self, strict: bool, **kwargs) -> exp.Expr: 1311 to = kwargs.get("to") 1312 if not strict and to and to.this == exp.DataType.Type.BOOLEAN: 1313 return self.expression(exp.ToBoolean(this=kwargs.get("this"), safe=True)) 1314 cast = super().build_cast(strict, **kwargs) 1315 if isinstance(cast, exp.TryCast) and to: 1316 if to.this in exp.DataType.TEXT_TYPES and to.expressions: 1317 cast.set("null_on_text_overflow", True) 1318 elif to.this == exp.DType.DATE and cast.this.is_string: 1319 cast.set("probe_date_format", True) 1320 return cast 1321 1322 def _parse_window(self, this: exp.Expr | None, alias: bool = False) -> exp.Expr | None: 1323 if isinstance(this, exp.NthValue): 1324 if self._match_text_seq("FROM"): 1325 if self._match_texts(("FIRST", "LAST")): 1326 from_first = self._prev.text.upper() == "FIRST" 1327 this.set("from_first", from_first) 1328 1329 result = super()._parse_window(this, alias) 1330 1331 # Set default window frame for ranking functions if not present 1332 if ( 1333 isinstance(result, exp.Window) 1334 and isinstance(this, RANKING_WINDOW_FUNCTIONS_WITH_FRAME) 1335 and not result.args.get("spec") 1336 ): 1337 frame = exp.WindowSpec( 1338 kind="ROWS", 1339 start="UNBOUNDED", 1340 start_side="PRECEDING", 1341 end="UNBOUNDED", 1342 end_side="FOLLOWING", 1343 ) 1344 result.set("spec", frame) 1345 return result
Parser consumes a list of tokens produced by the Tokenizer and produces a parsed syntax tree.
Arguments:
- error_level: The desired error level. Default: ErrorLevel.IMMEDIATE
- error_message_context: The amount of context to capture from a query string when displaying the error message (in number of characters). Default: 100
- max_errors: Maximum number of error messages to include in a raised ParseError. This is only relevant if error_level is ErrorLevel.RAISE. Default: 3
- max_nodes: Maximum number of AST nodes to prevent memory exhaustion. Set to -1 (default) to disable the check.
TYPE_TOKENS =
{<TokenType.BIT: 96>, <TokenType.BOOLEAN: 97>, <TokenType.TINYINT: 98>, <TokenType.UTINYINT: 99>, <TokenType.SMALLINT: 100>, <TokenType.USMALLINT: 101>, <TokenType.MEDIUMINT: 102>, <TokenType.UMEDIUMINT: 103>, <TokenType.INT: 104>, <TokenType.UINT: 105>, <TokenType.BIGINT: 106>, <TokenType.UBIGINT: 107>, <TokenType.BIGNUM: 108>, <TokenType.INT128: 109>, <TokenType.UINT128: 110>, <TokenType.INT256: 111>, <TokenType.UINT256: 112>, <TokenType.FLOAT: 113>, <TokenType.DOUBLE: 114>, <TokenType.UDOUBLE: 115>, <TokenType.DECIMAL: 116>, <TokenType.DECIMAL32: 117>, <TokenType.DECIMAL64: 118>, <TokenType.DECIMAL128: 119>, <TokenType.DECIMAL256: 120>, <TokenType.DECFLOAT: 121>, <TokenType.UDECIMAL: 122>, <TokenType.BIGDECIMAL: 123>, <TokenType.CHAR: 124>, <TokenType.NCHAR: 125>, <TokenType.VARCHAR: 126>, <TokenType.NVARCHAR: 127>, <TokenType.BPCHAR: 128>, <TokenType.TEXT: 129>, <TokenType.MEDIUMTEXT: 130>, <TokenType.LONGTEXT: 131>, <TokenType.BLOB: 132>, <TokenType.MEDIUMBLOB: 133>, <TokenType.LONGBLOB: 134>, <TokenType.TINYBLOB: 135>, <TokenType.TINYTEXT: 136>, <TokenType.NAME: 137>, <TokenType.BINARY: 138>, <TokenType.VARBINARY: 139>, <TokenType.JSON: 140>, <TokenType.JSONB: 141>, <TokenType.TIME: 142>, <TokenType.TIMETZ: 143>, <TokenType.TIME_NS: 144>, <TokenType.TIMESTAMP: 145>, <TokenType.TIMESTAMPTZ: 146>, <TokenType.TIMESTAMPLTZ: 147>, <TokenType.TIMESTAMPNTZ: 148>, <TokenType.TIMESTAMP_S: 149>, <TokenType.TIMESTAMP_MS: 150>, <TokenType.TIMESTAMP_NS: 151>, <TokenType.DATETIME: 152>, <TokenType.DATETIME2: 153>, <TokenType.DATETIME64: 154>, <TokenType.SMALLDATETIME: 155>, <TokenType.DATE: 156>, <TokenType.DATE32: 157>, <TokenType.INT4RANGE: 158>, <TokenType.INT4MULTIRANGE: 159>, <TokenType.INT8RANGE: 160>, <TokenType.INT8MULTIRANGE: 161>, <TokenType.NUMRANGE: 162>, <TokenType.NUMMULTIRANGE: 163>, <TokenType.TSRANGE: 164>, <TokenType.TSMULTIRANGE: 165>, <TokenType.TSTZRANGE: 166>, <TokenType.TSTZMULTIRANGE: 167>, <TokenType.DATERANGE: 168>, <TokenType.DATEMULTIRANGE: 169>, <TokenType.UUID: 170>, <TokenType.GEOGRAPHY: 171>, <TokenType.GEOGRAPHYPOINT: 172>, <TokenType.NULLABLE: 173>, <TokenType.GEOMETRY: 174>, <TokenType.POINT: 175>, <TokenType.RING: 176>, <TokenType.LINESTRING: 177>, <TokenType.MULTILINESTRING: 181>, <TokenType.POLYGON: 182>, <TokenType.MULTIPOLYGON: 183>, <TokenType.HLLSKETCH: 184>, <TokenType.HSTORE: 185>, <TokenType.SUPER: 186>, <TokenType.SERIAL: 187>, <TokenType.SMALLSERIAL: 188>, <TokenType.BIGSERIAL: 189>, <TokenType.XML: 190>, <TokenType.YEAR: 191>, <TokenType.USERDEFINED: 192>, <TokenType.MONEY: 193>, <TokenType.SMALLMONEY: 194>, <TokenType.ROWVERSION: 195>, <TokenType.IMAGE: 196>, <TokenType.VARIANT: 197>, <TokenType.OBJECT: 198>, <TokenType.INET: 199>, <TokenType.IPADDRESS: 200>, <TokenType.IPPREFIX: 201>, <TokenType.IPV4: 202>, <TokenType.IPV6: 203>, <TokenType.ENUM: 204>, <TokenType.ENUM8: 205>, <TokenType.ENUM16: 206>, <TokenType.FIXEDSTRING: 207>, <TokenType.LOWCARDINALITY: 208>, <TokenType.NESTED: 209>, <TokenType.AGGREGATEFUNCTION: 210>, <TokenType.SIMPLEAGGREGATEFUNCTION: 211>, <TokenType.TDIGEST: 212>, <TokenType.UNKNOWN: 213>, <TokenType.VECTOR: 214>, <TokenType.DYNAMIC: 215>, <TokenType.VOID: 216>, <TokenType.ARRAY: 223>, <TokenType.FILE: 273>, <TokenType.INTERVAL: 303>, <TokenType.LIST: 319>, <TokenType.MAP: 322>, <TokenType.NOTHING: 332>, <TokenType.NULL: 334>, <TokenType.OBJECT_IDENTIFIER: 335>, <TokenType.PSEUDO_TYPE: 364>, <TokenType.RANGE: 369>, <TokenType.STRUCT: 401>, <TokenType.UNION: 413>}
STRUCT_TYPE_TOKENS =
{<TokenType.OBJECT: 198>, <TokenType.NESTED: 209>, <TokenType.STRUCT: 401>, <TokenType.FILE: 273>, <TokenType.UNION: 413>}
NESTED_TYPE_TOKENS =
{<TokenType.MAP: 322>, <TokenType.ARRAY: 223>, <TokenType.OBJECT: 198>, <TokenType.NULLABLE: 173>, <TokenType.LOWCARDINALITY: 208>, <TokenType.RANGE: 369>, <TokenType.NESTED: 209>, <TokenType.STRUCT: 401>, <TokenType.FILE: 273>, <TokenType.UNION: 413>, <TokenType.LIST: 319>}
ID_VAR_TOKENS =
{<TokenType.SESSION: 58>, <TokenType.SESSION_USER: 60>, <TokenType.IDENTIFIER: 78>, <TokenType.DATABASE: 79>, <TokenType.COLUMN: 80>, <TokenType.SCHEMA: 82>, <TokenType.TABLE: 83>, <TokenType.WAREHOUSE: 84>, <TokenType.STAGE: 85>, <TokenType.STREAM: 86>, <TokenType.STREAMLIT: 87>, <TokenType.VAR: 88>, <TokenType.BIT: 96>, <TokenType.BOOLEAN: 97>, <TokenType.TINYINT: 98>, <TokenType.UTINYINT: 99>, <TokenType.SMALLINT: 100>, <TokenType.USMALLINT: 101>, <TokenType.MEDIUMINT: 102>, <TokenType.UMEDIUMINT: 103>, <TokenType.INT: 104>, <TokenType.UINT: 105>, <TokenType.BIGINT: 106>, <TokenType.UBIGINT: 107>, <TokenType.BIGNUM: 108>, <TokenType.INT128: 109>, <TokenType.UINT128: 110>, <TokenType.INT256: 111>, <TokenType.UINT256: 112>, <TokenType.FLOAT: 113>, <TokenType.DOUBLE: 114>, <TokenType.UDOUBLE: 115>, <TokenType.DECIMAL: 116>, <TokenType.DECIMAL32: 117>, <TokenType.DECIMAL64: 118>, <TokenType.DECIMAL128: 119>, <TokenType.DECIMAL256: 120>, <TokenType.DECFLOAT: 121>, <TokenType.UDECIMAL: 122>, <TokenType.BIGDECIMAL: 123>, <TokenType.CHAR: 124>, <TokenType.NCHAR: 125>, <TokenType.VARCHAR: 126>, <TokenType.NVARCHAR: 127>, <TokenType.BPCHAR: 128>, <TokenType.TEXT: 129>, <TokenType.MEDIUMTEXT: 130>, <TokenType.LONGTEXT: 131>, <TokenType.BLOB: 132>, <TokenType.MEDIUMBLOB: 133>, <TokenType.LONGBLOB: 134>, <TokenType.TINYBLOB: 135>, <TokenType.TINYTEXT: 136>, <TokenType.NAME: 137>, <TokenType.BINARY: 138>, <TokenType.VARBINARY: 139>, <TokenType.JSON: 140>, <TokenType.JSONB: 141>, <TokenType.TIME: 142>, <TokenType.TIMETZ: 143>, <TokenType.TIME_NS: 144>, <TokenType.TIMESTAMP: 145>, <TokenType.TIMESTAMPTZ: 146>, <TokenType.TIMESTAMPLTZ: 147>, <TokenType.TIMESTAMPNTZ: 148>, <TokenType.TIMESTAMP_S: 149>, <TokenType.TIMESTAMP_MS: 150>, <TokenType.TIMESTAMP_NS: 151>, <TokenType.DATETIME: 152>, <TokenType.DATETIME2: 153>, <TokenType.DATETIME64: 154>, <TokenType.SMALLDATETIME: 155>, <TokenType.DATE: 156>, <TokenType.DATE32: 157>, <TokenType.INT4RANGE: 158>, <TokenType.INT4MULTIRANGE: 159>, <TokenType.INT8RANGE: 160>, <TokenType.INT8MULTIRANGE: 161>, <TokenType.NUMRANGE: 162>, <TokenType.NUMMULTIRANGE: 163>, <TokenType.TSRANGE: 164>, <TokenType.TSMULTIRANGE: 165>, <TokenType.TSTZRANGE: 166>, <TokenType.TSTZMULTIRANGE: 167>, <TokenType.DATERANGE: 168>, <TokenType.DATEMULTIRANGE: 169>, <TokenType.UUID: 170>, <TokenType.GEOGRAPHY: 171>, <TokenType.GEOGRAPHYPOINT: 172>, <TokenType.NULLABLE: 173>, <TokenType.GEOMETRY: 174>, <TokenType.POINT: 175>, <TokenType.RING: 176>, <TokenType.LINESTRING: 177>, <TokenType.LOCALTIME: 178>, <TokenType.LOCALTIMESTAMP: 179>, <TokenType.MULTILINESTRING: 181>, <TokenType.POLYGON: 182>, <TokenType.MULTIPOLYGON: 183>, <TokenType.HLLSKETCH: 184>, <TokenType.HSTORE: 185>, <TokenType.SUPER: 186>, <TokenType.SERIAL: 187>, <TokenType.SMALLSERIAL: 188>, <TokenType.BIGSERIAL: 189>, <TokenType.XML: 190>, <TokenType.YEAR: 191>, <TokenType.USERDEFINED: 192>, <TokenType.MONEY: 193>, <TokenType.SMALLMONEY: 194>, <TokenType.ROWVERSION: 195>, <TokenType.IMAGE: 196>, <TokenType.VARIANT: 197>, <TokenType.OBJECT: 198>, <TokenType.INET: 199>, <TokenType.IPADDRESS: 200>, <TokenType.IPPREFIX: 201>, <TokenType.IPV4: 202>, <TokenType.IPV6: 203>, <TokenType.ENUM: 204>, <TokenType.ENUM8: 205>, <TokenType.ENUM16: 206>, <TokenType.FIXEDSTRING: 207>, <TokenType.LOWCARDINALITY: 208>, <TokenType.NESTED: 209>, <TokenType.AGGREGATEFUNCTION: 210>, <TokenType.SIMPLEAGGREGATEFUNCTION: 211>, <TokenType.TDIGEST: 212>, <TokenType.UNKNOWN: 213>, <TokenType.VECTOR: 214>, <TokenType.DYNAMIC: 215>, <TokenType.VOID: 216>, <TokenType.ALL: 219>, <TokenType.ANTI: 220>, <TokenType.ANY: 221>, <TokenType.APPLY: 222>, <TokenType.ARRAY: 223>, <TokenType.ASC: 224>, <TokenType.ASOF: 225>, <TokenType.ATTACH: 226>, <TokenType.AUTO_INCREMENT: 227>, <TokenType.BEGIN: 228>, <TokenType.CACHE: 231>, <TokenType.CASE: 232>, <TokenType.COLLATE: 235>, <TokenType.COMMAND: 236>, <TokenType.COMMENT: 237>, <TokenType.COMMIT: 238>, <TokenType.CONSTRAINT: 240>, <TokenType.COPY: 241>, <TokenType.CUBE: 244>, <TokenType.CURRENT_DATE: 245>, <TokenType.CURRENT_DATETIME: 246>, <TokenType.CURRENT_SCHEMA: 247>, <TokenType.CURRENT_TIME: 248>, <TokenType.CURRENT_TIMESTAMP: 249>, <TokenType.CURRENT_USER: 250>, <TokenType.CURRENT_ROLE: 252>, <TokenType.CURRENT_CATALOG: 253>, <TokenType.DEFAULT: 255>, <TokenType.DELETE: 256>, <TokenType.DESC: 257>, <TokenType.DESCRIBE: 258>, <TokenType.DETACH: 259>, <TokenType.DICTIONARY: 260>, <TokenType.DIV: 263>, <TokenType.END: 266>, <TokenType.ESCAPE: 267>, <TokenType.EXCEPT: 268>, <TokenType.EXECUTE: 269>, <TokenType.EXISTS: 270>, <TokenType.FALSE: 271>, <TokenType.FILE: 273>, <TokenType.FILE_FORMAT: 274>, <TokenType.FILTER: 275>, <TokenType.FINAL: 276>, <TokenType.FIRST: 277>, <TokenType.FOREIGN_KEY: 280>, <TokenType.FORMAT: 281>, <TokenType.FULL: 283>, <TokenType.FUNCTION: 284>, <TokenType.GET: 285>, <TokenType.INDEX: 296>, <TokenType.INTEGRATION: 301>, <TokenType.INTERVAL: 303>, <TokenType.IS: 307>, <TokenType.ISNULL: 308>, <TokenType.KEEP: 311>, <TokenType.KILL: 313>, <TokenType.LEFT: 316>, <TokenType.LIMIT: 318>, <TokenType.LIST: 319>, <TokenType.LOAD: 320>, <TokenType.LOCK: 321>, <TokenType.MAP: 322>, <TokenType.MATCH: 323>, <TokenType.MATCH_CONDITION: 324>, <TokenType.MERGE: 327>, <TokenType.MODEL: 329>, <TokenType.NATURAL: 330>, <TokenType.NEXT: 331>, <TokenType.NOTHING: 332>, <TokenType.NULL: 334>, <TokenType.OBJECT_IDENTIFIER: 335>, <TokenType.OFFSET: 336>, <TokenType.OPERATOR: 339>, <TokenType.ORDINALITY: 343>, <TokenType.INOUT: 345>, <TokenType.OVER: 347>, <TokenType.OVERLAPS: 348>, <TokenType.OVERWRITE: 349>, <TokenType.PACKAGE: 350>, <TokenType.PARTITION: 351>, <TokenType.PERCENT: 353>, <TokenType.PIVOT: 354>, <TokenType.POLICY: 356>, <TokenType.POOL: 357>, <TokenType.PRAGMA: 359>, <TokenType.PROCEDURE: 362>, <TokenType.PSEUDO_TYPE: 364>, <TokenType.PUT: 365>, <TokenType.RANGE: 369>, <TokenType.RECURSIVE: 370>, <TokenType.REFRESH: 371>, <TokenType.RENAME: 372>, <TokenType.REPLACE: 373>, <TokenType.REFERENCES: 376>, <TokenType.RIGHT: 377>, <TokenType.ROLE: 379>, <TokenType.ROLLUP: 381>, <TokenType.ROW: 382>, <TokenType.ROWS: 383>, <TokenType.RULE: 384>, <TokenType.SEMI: 386>, <TokenType.SEQUENCE: 388>, <TokenType.SET: 390>, <TokenType.SETTINGS: 391>, <TokenType.SHOW: 392>, <TokenType.SOME: 394>, <TokenType.STORAGE_INTEGRATION: 399>, <TokenType.STRAIGHT_JOIN: 400>, <TokenType.STRUCT: 401>, <TokenType.TAG: 404>, <TokenType.TEMPORARY: 405>, <TokenType.TOP: 406>, <TokenType.TRUE: 408>, <TokenType.TRUNCATE: 409>, <TokenType.TRIGGER: 410>, <TokenType.TYPE: 411>, <TokenType.UNNEST: 414>, <TokenType.UNPIVOT: 415>, <TokenType.UPDATE: 416>, <TokenType.USE: 417>, <TokenType.VIEW: 421>, <TokenType.SEMANTIC_VIEW: 422>, <TokenType.VOLATILE: 423>, <TokenType.VOLUME: 424>, <TokenType.WINDOW: 427>, <TokenType.UNIQUE: 429>, <TokenType.SINK: 436>, <TokenType.SOURCE: 437>, <TokenType.ANALYZE: 438>, <TokenType.NAMESPACE: 439>, <TokenType.EXPORT: 440>}
ALIAS_TOKENS =
{<TokenType.SESSION: 58>, <TokenType.SESSION_USER: 60>, <TokenType.IDENTIFIER: 78>, <TokenType.DATABASE: 79>, <TokenType.COLUMN: 80>, <TokenType.SCHEMA: 82>, <TokenType.TABLE: 83>, <TokenType.WAREHOUSE: 84>, <TokenType.STAGE: 85>, <TokenType.STREAM: 86>, <TokenType.STREAMLIT: 87>, <TokenType.VAR: 88>, <TokenType.BIT: 96>, <TokenType.BOOLEAN: 97>, <TokenType.TINYINT: 98>, <TokenType.UTINYINT: 99>, <TokenType.SMALLINT: 100>, <TokenType.USMALLINT: 101>, <TokenType.MEDIUMINT: 102>, <TokenType.UMEDIUMINT: 103>, <TokenType.INT: 104>, <TokenType.UINT: 105>, <TokenType.BIGINT: 106>, <TokenType.UBIGINT: 107>, <TokenType.BIGNUM: 108>, <TokenType.INT128: 109>, <TokenType.UINT128: 110>, <TokenType.INT256: 111>, <TokenType.UINT256: 112>, <TokenType.FLOAT: 113>, <TokenType.DOUBLE: 114>, <TokenType.UDOUBLE: 115>, <TokenType.DECIMAL: 116>, <TokenType.DECIMAL32: 117>, <TokenType.DECIMAL64: 118>, <TokenType.DECIMAL128: 119>, <TokenType.DECIMAL256: 120>, <TokenType.DECFLOAT: 121>, <TokenType.UDECIMAL: 122>, <TokenType.BIGDECIMAL: 123>, <TokenType.CHAR: 124>, <TokenType.NCHAR: 125>, <TokenType.VARCHAR: 126>, <TokenType.NVARCHAR: 127>, <TokenType.BPCHAR: 128>, <TokenType.TEXT: 129>, <TokenType.MEDIUMTEXT: 130>, <TokenType.LONGTEXT: 131>, <TokenType.BLOB: 132>, <TokenType.MEDIUMBLOB: 133>, <TokenType.LONGBLOB: 134>, <TokenType.TINYBLOB: 135>, <TokenType.TINYTEXT: 136>, <TokenType.NAME: 137>, <TokenType.BINARY: 138>, <TokenType.VARBINARY: 139>, <TokenType.JSON: 140>, <TokenType.JSONB: 141>, <TokenType.TIME: 142>, <TokenType.TIMETZ: 143>, <TokenType.TIME_NS: 144>, <TokenType.TIMESTAMP: 145>, <TokenType.TIMESTAMPTZ: 146>, <TokenType.TIMESTAMPLTZ: 147>, <TokenType.TIMESTAMPNTZ: 148>, <TokenType.TIMESTAMP_S: 149>, <TokenType.TIMESTAMP_MS: 150>, <TokenType.TIMESTAMP_NS: 151>, <TokenType.DATETIME: 152>, <TokenType.DATETIME2: 153>, <TokenType.DATETIME64: 154>, <TokenType.SMALLDATETIME: 155>, <TokenType.DATE: 156>, <TokenType.DATE32: 157>, <TokenType.INT4RANGE: 158>, <TokenType.INT4MULTIRANGE: 159>, <TokenType.INT8RANGE: 160>, <TokenType.INT8MULTIRANGE: 161>, <TokenType.NUMRANGE: 162>, <TokenType.NUMMULTIRANGE: 163>, <TokenType.TSRANGE: 164>, <TokenType.TSMULTIRANGE: 165>, <TokenType.TSTZRANGE: 166>, <TokenType.TSTZMULTIRANGE: 167>, <TokenType.DATERANGE: 168>, <TokenType.DATEMULTIRANGE: 169>, <TokenType.UUID: 170>, <TokenType.GEOGRAPHY: 171>, <TokenType.GEOGRAPHYPOINT: 172>, <TokenType.NULLABLE: 173>, <TokenType.GEOMETRY: 174>, <TokenType.POINT: 175>, <TokenType.RING: 176>, <TokenType.LINESTRING: 177>, <TokenType.LOCALTIME: 178>, <TokenType.LOCALTIMESTAMP: 179>, <TokenType.MULTILINESTRING: 181>, <TokenType.POLYGON: 182>, <TokenType.MULTIPOLYGON: 183>, <TokenType.HLLSKETCH: 184>, <TokenType.HSTORE: 185>, <TokenType.SUPER: 186>, <TokenType.SERIAL: 187>, <TokenType.SMALLSERIAL: 188>, <TokenType.BIGSERIAL: 189>, <TokenType.XML: 190>, <TokenType.YEAR: 191>, <TokenType.USERDEFINED: 192>, <TokenType.MONEY: 193>, <TokenType.SMALLMONEY: 194>, <TokenType.ROWVERSION: 195>, <TokenType.IMAGE: 196>, <TokenType.VARIANT: 197>, <TokenType.OBJECT: 198>, <TokenType.INET: 199>, <TokenType.IPADDRESS: 200>, <TokenType.IPPREFIX: 201>, <TokenType.IPV4: 202>, <TokenType.IPV6: 203>, <TokenType.ENUM: 204>, <TokenType.ENUM8: 205>, <TokenType.ENUM16: 206>, <TokenType.FIXEDSTRING: 207>, <TokenType.LOWCARDINALITY: 208>, <TokenType.NESTED: 209>, <TokenType.AGGREGATEFUNCTION: 210>, <TokenType.SIMPLEAGGREGATEFUNCTION: 211>, <TokenType.TDIGEST: 212>, <TokenType.UNKNOWN: 213>, <TokenType.VECTOR: 214>, <TokenType.DYNAMIC: 215>, <TokenType.VOID: 216>, <TokenType.ALL: 219>, <TokenType.ANTI: 220>, <TokenType.ANY: 221>, <TokenType.APPLY: 222>, <TokenType.ARRAY: 223>, <TokenType.ASC: 224>, <TokenType.ASOF: 225>, <TokenType.ATTACH: 226>, <TokenType.AUTO_INCREMENT: 227>, <TokenType.BEGIN: 228>, <TokenType.CACHE: 231>, <TokenType.CASE: 232>, <TokenType.COLLATE: 235>, <TokenType.COMMAND: 236>, <TokenType.COMMENT: 237>, <TokenType.COMMIT: 238>, <TokenType.CONSTRAINT: 240>, <TokenType.COPY: 241>, <TokenType.CUBE: 244>, <TokenType.CURRENT_DATE: 245>, <TokenType.CURRENT_DATETIME: 246>, <TokenType.CURRENT_SCHEMA: 247>, <TokenType.CURRENT_TIME: 248>, <TokenType.CURRENT_TIMESTAMP: 249>, <TokenType.CURRENT_USER: 250>, <TokenType.CURRENT_ROLE: 252>, <TokenType.CURRENT_CATALOG: 253>, <TokenType.DEFAULT: 255>, <TokenType.DELETE: 256>, <TokenType.DESC: 257>, <TokenType.DESCRIBE: 258>, <TokenType.DETACH: 259>, <TokenType.DICTIONARY: 260>, <TokenType.DIV: 263>, <TokenType.END: 266>, <TokenType.ESCAPE: 267>, <TokenType.EXECUTE: 269>, <TokenType.EXISTS: 270>, <TokenType.FALSE: 271>, <TokenType.FILE: 273>, <TokenType.FILE_FORMAT: 274>, <TokenType.FILTER: 275>, <TokenType.FINAL: 276>, <TokenType.FIRST: 277>, <TokenType.FOREIGN_KEY: 280>, <TokenType.FORMAT: 281>, <TokenType.FULL: 283>, <TokenType.FUNCTION: 284>, <TokenType.GET: 285>, <TokenType.INDEX: 296>, <TokenType.INTEGRATION: 301>, <TokenType.INTERVAL: 303>, <TokenType.IS: 307>, <TokenType.ISNULL: 308>, <TokenType.KEEP: 311>, <TokenType.KILL: 313>, <TokenType.LEFT: 316>, <TokenType.LIMIT: 318>, <TokenType.LIST: 319>, <TokenType.LOAD: 320>, <TokenType.LOCK: 321>, <TokenType.MAP: 322>, <TokenType.MATCH: 323>, <TokenType.MERGE: 327>, <TokenType.MODEL: 329>, <TokenType.NATURAL: 330>, <TokenType.NEXT: 331>, <TokenType.NOTHING: 332>, <TokenType.NULL: 334>, <TokenType.OBJECT_IDENTIFIER: 335>, <TokenType.OFFSET: 336>, <TokenType.OPERATOR: 339>, <TokenType.ORDINALITY: 343>, <TokenType.INOUT: 345>, <TokenType.OVER: 347>, <TokenType.OVERLAPS: 348>, <TokenType.OVERWRITE: 349>, <TokenType.PACKAGE: 350>, <TokenType.PARTITION: 351>, <TokenType.PERCENT: 353>, <TokenType.PIVOT: 354>, <TokenType.POLICY: 356>, <TokenType.POOL: 357>, <TokenType.PRAGMA: 359>, <TokenType.PROCEDURE: 362>, <TokenType.PSEUDO_TYPE: 364>, <TokenType.PUT: 365>, <TokenType.RANGE: 369>, <TokenType.RECURSIVE: 370>, <TokenType.REFRESH: 371>, <TokenType.RENAME: 372>, <TokenType.REPLACE: 373>, <TokenType.REFERENCES: 376>, <TokenType.RIGHT: 377>, <TokenType.ROLE: 379>, <TokenType.ROLLUP: 381>, <TokenType.ROW: 382>, <TokenType.ROWS: 383>, <TokenType.RULE: 384>, <TokenType.SEMI: 386>, <TokenType.SEQUENCE: 388>, <TokenType.SET: 390>, <TokenType.SETTINGS: 391>, <TokenType.SHOW: 392>, <TokenType.SOME: 394>, <TokenType.STORAGE_INTEGRATION: 399>, <TokenType.STRAIGHT_JOIN: 400>, <TokenType.STRUCT: 401>, <TokenType.TAG: 404>, <TokenType.TEMPORARY: 405>, <TokenType.TOP: 406>, <TokenType.TRUE: 408>, <TokenType.TRUNCATE: 409>, <TokenType.TRIGGER: 410>, <TokenType.TYPE: 411>, <TokenType.UNNEST: 414>, <TokenType.UNPIVOT: 415>, <TokenType.UPDATE: 416>, <TokenType.USE: 417>, <TokenType.VIEW: 421>, <TokenType.SEMANTIC_VIEW: 422>, <TokenType.VOLATILE: 423>, <TokenType.VOLUME: 424>, <TokenType.WINDOW: 427>, <TokenType.UNIQUE: 429>, <TokenType.SINK: 436>, <TokenType.SOURCE: 437>, <TokenType.ANALYZE: 438>, <TokenType.NAMESPACE: 439>, <TokenType.EXPORT: 440>}
TABLE_ALIAS_TOKENS =
{<TokenType.SESSION: 58>, <TokenType.SESSION_USER: 60>, <TokenType.IDENTIFIER: 78>, <TokenType.DATABASE: 79>, <TokenType.COLUMN: 80>, <TokenType.SCHEMA: 82>, <TokenType.TABLE: 83>, <TokenType.WAREHOUSE: 84>, <TokenType.STAGE: 85>, <TokenType.STREAM: 86>, <TokenType.STREAMLIT: 87>, <TokenType.VAR: 88>, <TokenType.BIT: 96>, <TokenType.BOOLEAN: 97>, <TokenType.TINYINT: 98>, <TokenType.UTINYINT: 99>, <TokenType.SMALLINT: 100>, <TokenType.USMALLINT: 101>, <TokenType.MEDIUMINT: 102>, <TokenType.UMEDIUMINT: 103>, <TokenType.INT: 104>, <TokenType.UINT: 105>, <TokenType.BIGINT: 106>, <TokenType.UBIGINT: 107>, <TokenType.BIGNUM: 108>, <TokenType.INT128: 109>, <TokenType.UINT128: 110>, <TokenType.INT256: 111>, <TokenType.UINT256: 112>, <TokenType.FLOAT: 113>, <TokenType.DOUBLE: 114>, <TokenType.UDOUBLE: 115>, <TokenType.DECIMAL: 116>, <TokenType.DECIMAL32: 117>, <TokenType.DECIMAL64: 118>, <TokenType.DECIMAL128: 119>, <TokenType.DECIMAL256: 120>, <TokenType.DECFLOAT: 121>, <TokenType.UDECIMAL: 122>, <TokenType.BIGDECIMAL: 123>, <TokenType.CHAR: 124>, <TokenType.NCHAR: 125>, <TokenType.VARCHAR: 126>, <TokenType.NVARCHAR: 127>, <TokenType.BPCHAR: 128>, <TokenType.TEXT: 129>, <TokenType.MEDIUMTEXT: 130>, <TokenType.LONGTEXT: 131>, <TokenType.BLOB: 132>, <TokenType.MEDIUMBLOB: 133>, <TokenType.LONGBLOB: 134>, <TokenType.TINYBLOB: 135>, <TokenType.TINYTEXT: 136>, <TokenType.NAME: 137>, <TokenType.BINARY: 138>, <TokenType.VARBINARY: 139>, <TokenType.JSON: 140>, <TokenType.JSONB: 141>, <TokenType.TIME: 142>, <TokenType.TIMETZ: 143>, <TokenType.TIME_NS: 144>, <TokenType.TIMESTAMP: 145>, <TokenType.TIMESTAMPTZ: 146>, <TokenType.TIMESTAMPLTZ: 147>, <TokenType.TIMESTAMPNTZ: 148>, <TokenType.TIMESTAMP_S: 149>, <TokenType.TIMESTAMP_MS: 150>, <TokenType.TIMESTAMP_NS: 151>, <TokenType.DATETIME: 152>, <TokenType.DATETIME2: 153>, <TokenType.DATETIME64: 154>, <TokenType.SMALLDATETIME: 155>, <TokenType.DATE: 156>, <TokenType.DATE32: 157>, <TokenType.INT4RANGE: 158>, <TokenType.INT4MULTIRANGE: 159>, <TokenType.INT8RANGE: 160>, <TokenType.INT8MULTIRANGE: 161>, <TokenType.NUMRANGE: 162>, <TokenType.NUMMULTIRANGE: 163>, <TokenType.TSRANGE: 164>, <TokenType.TSMULTIRANGE: 165>, <TokenType.TSTZRANGE: 166>, <TokenType.TSTZMULTIRANGE: 167>, <TokenType.DATERANGE: 168>, <TokenType.DATEMULTIRANGE: 169>, <TokenType.UUID: 170>, <TokenType.GEOGRAPHY: 171>, <TokenType.GEOGRAPHYPOINT: 172>, <TokenType.NULLABLE: 173>, <TokenType.GEOMETRY: 174>, <TokenType.POINT: 175>, <TokenType.RING: 176>, <TokenType.LINESTRING: 177>, <TokenType.LOCALTIME: 178>, <TokenType.LOCALTIMESTAMP: 179>, <TokenType.MULTILINESTRING: 181>, <TokenType.POLYGON: 182>, <TokenType.MULTIPOLYGON: 183>, <TokenType.HLLSKETCH: 184>, <TokenType.HSTORE: 185>, <TokenType.SUPER: 186>, <TokenType.SERIAL: 187>, <TokenType.SMALLSERIAL: 188>, <TokenType.BIGSERIAL: 189>, <TokenType.XML: 190>, <TokenType.YEAR: 191>, <TokenType.USERDEFINED: 192>, <TokenType.MONEY: 193>, <TokenType.SMALLMONEY: 194>, <TokenType.ROWVERSION: 195>, <TokenType.IMAGE: 196>, <TokenType.VARIANT: 197>, <TokenType.OBJECT: 198>, <TokenType.INET: 199>, <TokenType.IPADDRESS: 200>, <TokenType.IPPREFIX: 201>, <TokenType.IPV4: 202>, <TokenType.IPV6: 203>, <TokenType.ENUM: 204>, <TokenType.ENUM8: 205>, <TokenType.ENUM16: 206>, <TokenType.FIXEDSTRING: 207>, <TokenType.LOWCARDINALITY: 208>, <TokenType.NESTED: 209>, <TokenType.AGGREGATEFUNCTION: 210>, <TokenType.SIMPLEAGGREGATEFUNCTION: 211>, <TokenType.TDIGEST: 212>, <TokenType.UNKNOWN: 213>, <TokenType.VECTOR: 214>, <TokenType.DYNAMIC: 215>, <TokenType.VOID: 216>, <TokenType.ALL: 219>, <TokenType.ANTI: 220>, <TokenType.ANY: 221>, <TokenType.APPLY: 222>, <TokenType.ARRAY: 223>, <TokenType.ASC: 224>, <TokenType.ATTACH: 226>, <TokenType.AUTO_INCREMENT: 227>, <TokenType.BEGIN: 228>, <TokenType.CACHE: 231>, <TokenType.CASE: 232>, <TokenType.COLLATE: 235>, <TokenType.COMMAND: 236>, <TokenType.COMMENT: 237>, <TokenType.COMMIT: 238>, <TokenType.CONSTRAINT: 240>, <TokenType.COPY: 241>, <TokenType.CUBE: 244>, <TokenType.CURRENT_DATE: 245>, <TokenType.CURRENT_DATETIME: 246>, <TokenType.CURRENT_SCHEMA: 247>, <TokenType.CURRENT_TIME: 248>, <TokenType.CURRENT_TIMESTAMP: 249>, <TokenType.CURRENT_USER: 250>, <TokenType.CURRENT_ROLE: 252>, <TokenType.CURRENT_CATALOG: 253>, <TokenType.DEFAULT: 255>, <TokenType.DELETE: 256>, <TokenType.DESC: 257>, <TokenType.DESCRIBE: 258>, <TokenType.DETACH: 259>, <TokenType.DICTIONARY: 260>, <TokenType.DIV: 263>, <TokenType.END: 266>, <TokenType.ESCAPE: 267>, <TokenType.EXECUTE: 269>, <TokenType.EXISTS: 270>, <TokenType.FALSE: 271>, <TokenType.FILE: 273>, <TokenType.FILE_FORMAT: 274>, <TokenType.FILTER: 275>, <TokenType.FINAL: 276>, <TokenType.FIRST: 277>, <TokenType.FOREIGN_KEY: 280>, <TokenType.FORMAT: 281>, <TokenType.FUNCTION: 284>, <TokenType.GET: 285>, <TokenType.INDEX: 296>, <TokenType.INTEGRATION: 301>, <TokenType.INTERVAL: 303>, <TokenType.IS: 307>, <TokenType.ISNULL: 308>, <TokenType.KEEP: 311>, <TokenType.KILL: 313>, <TokenType.LIMIT: 318>, <TokenType.LIST: 319>, <TokenType.LOAD: 320>, <TokenType.MAP: 322>, <TokenType.MATCH: 323>, <TokenType.MERGE: 327>, <TokenType.MODEL: 329>, <TokenType.NEXT: 331>, <TokenType.NOTHING: 332>, <TokenType.NULL: 334>, <TokenType.OBJECT_IDENTIFIER: 335>, <TokenType.OFFSET: 336>, <TokenType.OPERATOR: 339>, <TokenType.ORDINALITY: 343>, <TokenType.INOUT: 345>, <TokenType.OVER: 347>, <TokenType.OVERLAPS: 348>, <TokenType.OVERWRITE: 349>, <TokenType.PACKAGE: 350>, <TokenType.PARTITION: 351>, <TokenType.PERCENT: 353>, <TokenType.PIVOT: 354>, <TokenType.POLICY: 356>, <TokenType.POOL: 357>, <TokenType.PRAGMA: 359>, <TokenType.PROCEDURE: 362>, <TokenType.PSEUDO_TYPE: 364>, <TokenType.PUT: 365>, <TokenType.RANGE: 369>, <TokenType.RECURSIVE: 370>, <TokenType.REFRESH: 371>, <TokenType.RENAME: 372>, <TokenType.REPLACE: 373>, <TokenType.REFERENCES: 376>, <TokenType.ROLE: 379>, <TokenType.ROLLUP: 381>, <TokenType.ROW: 382>, <TokenType.ROWS: 383>, <TokenType.RULE: 384>, <TokenType.SEMI: 386>, <TokenType.SEQUENCE: 388>, <TokenType.SET: 390>, <TokenType.SETTINGS: 391>, <TokenType.SHOW: 392>, <TokenType.SOME: 394>, <TokenType.STORAGE_INTEGRATION: 399>, <TokenType.STRAIGHT_JOIN: 400>, <TokenType.STRUCT: 401>, <TokenType.TAG: 404>, <TokenType.TEMPORARY: 405>, <TokenType.TOP: 406>, <TokenType.TRUE: 408>, <TokenType.TRUNCATE: 409>, <TokenType.TRIGGER: 410>, <TokenType.TYPE: 411>, <TokenType.UNNEST: 414>, <TokenType.UNPIVOT: 415>, <TokenType.UPDATE: 416>, <TokenType.USE: 417>, <TokenType.VIEW: 421>, <TokenType.SEMANTIC_VIEW: 422>, <TokenType.VOLATILE: 423>, <TokenType.VOLUME: 424>, <TokenType.WINDOW: 427>, <TokenType.UNIQUE: 429>, <TokenType.SINK: 436>, <TokenType.SOURCE: 437>, <TokenType.ANALYZE: 438>, <TokenType.NAMESPACE: 439>, <TokenType.EXPORT: 440>}
COLON_PLACEHOLDER_TOKENS =
{<TokenType.SESSION: 58>, <TokenType.SESSION_USER: 60>, <TokenType.NUMBER: 77>, <TokenType.IDENTIFIER: 78>, <TokenType.DATABASE: 79>, <TokenType.COLUMN: 80>, <TokenType.SCHEMA: 82>, <TokenType.TABLE: 83>, <TokenType.WAREHOUSE: 84>, <TokenType.STAGE: 85>, <TokenType.STREAM: 86>, <TokenType.STREAMLIT: 87>, <TokenType.VAR: 88>, <TokenType.BIT: 96>, <TokenType.BOOLEAN: 97>, <TokenType.TINYINT: 98>, <TokenType.UTINYINT: 99>, <TokenType.SMALLINT: 100>, <TokenType.USMALLINT: 101>, <TokenType.MEDIUMINT: 102>, <TokenType.UMEDIUMINT: 103>, <TokenType.INT: 104>, <TokenType.UINT: 105>, <TokenType.BIGINT: 106>, <TokenType.UBIGINT: 107>, <TokenType.BIGNUM: 108>, <TokenType.INT128: 109>, <TokenType.UINT128: 110>, <TokenType.INT256: 111>, <TokenType.UINT256: 112>, <TokenType.FLOAT: 113>, <TokenType.DOUBLE: 114>, <TokenType.UDOUBLE: 115>, <TokenType.DECIMAL: 116>, <TokenType.DECIMAL32: 117>, <TokenType.DECIMAL64: 118>, <TokenType.DECIMAL128: 119>, <TokenType.DECIMAL256: 120>, <TokenType.DECFLOAT: 121>, <TokenType.UDECIMAL: 122>, <TokenType.BIGDECIMAL: 123>, <TokenType.CHAR: 124>, <TokenType.NCHAR: 125>, <TokenType.VARCHAR: 126>, <TokenType.NVARCHAR: 127>, <TokenType.BPCHAR: 128>, <TokenType.TEXT: 129>, <TokenType.MEDIUMTEXT: 130>, <TokenType.LONGTEXT: 131>, <TokenType.BLOB: 132>, <TokenType.MEDIUMBLOB: 133>, <TokenType.LONGBLOB: 134>, <TokenType.TINYBLOB: 135>, <TokenType.TINYTEXT: 136>, <TokenType.NAME: 137>, <TokenType.BINARY: 138>, <TokenType.VARBINARY: 139>, <TokenType.JSON: 140>, <TokenType.JSONB: 141>, <TokenType.TIME: 142>, <TokenType.TIMETZ: 143>, <TokenType.TIME_NS: 144>, <TokenType.TIMESTAMP: 145>, <TokenType.TIMESTAMPTZ: 146>, <TokenType.TIMESTAMPLTZ: 147>, <TokenType.TIMESTAMPNTZ: 148>, <TokenType.TIMESTAMP_S: 149>, <TokenType.TIMESTAMP_MS: 150>, <TokenType.TIMESTAMP_NS: 151>, <TokenType.DATETIME: 152>, <TokenType.DATETIME2: 153>, <TokenType.DATETIME64: 154>, <TokenType.SMALLDATETIME: 155>, <TokenType.DATE: 156>, <TokenType.DATE32: 157>, <TokenType.INT4RANGE: 158>, <TokenType.INT4MULTIRANGE: 159>, <TokenType.INT8RANGE: 160>, <TokenType.INT8MULTIRANGE: 161>, <TokenType.NUMRANGE: 162>, <TokenType.NUMMULTIRANGE: 163>, <TokenType.TSRANGE: 164>, <TokenType.TSMULTIRANGE: 165>, <TokenType.TSTZRANGE: 166>, <TokenType.TSTZMULTIRANGE: 167>, <TokenType.DATERANGE: 168>, <TokenType.DATEMULTIRANGE: 169>, <TokenType.UUID: 170>, <TokenType.GEOGRAPHY: 171>, <TokenType.GEOGRAPHYPOINT: 172>, <TokenType.NULLABLE: 173>, <TokenType.GEOMETRY: 174>, <TokenType.POINT: 175>, <TokenType.RING: 176>, <TokenType.LINESTRING: 177>, <TokenType.LOCALTIME: 178>, <TokenType.LOCALTIMESTAMP: 179>, <TokenType.MULTILINESTRING: 181>, <TokenType.POLYGON: 182>, <TokenType.MULTIPOLYGON: 183>, <TokenType.HLLSKETCH: 184>, <TokenType.HSTORE: 185>, <TokenType.SUPER: 186>, <TokenType.SERIAL: 187>, <TokenType.SMALLSERIAL: 188>, <TokenType.BIGSERIAL: 189>, <TokenType.XML: 190>, <TokenType.YEAR: 191>, <TokenType.USERDEFINED: 192>, <TokenType.MONEY: 193>, <TokenType.SMALLMONEY: 194>, <TokenType.ROWVERSION: 195>, <TokenType.IMAGE: 196>, <TokenType.VARIANT: 197>, <TokenType.OBJECT: 198>, <TokenType.INET: 199>, <TokenType.IPADDRESS: 200>, <TokenType.IPPREFIX: 201>, <TokenType.IPV4: 202>, <TokenType.IPV6: 203>, <TokenType.ENUM: 204>, <TokenType.ENUM8: 205>, <TokenType.ENUM16: 206>, <TokenType.FIXEDSTRING: 207>, <TokenType.LOWCARDINALITY: 208>, <TokenType.NESTED: 209>, <TokenType.AGGREGATEFUNCTION: 210>, <TokenType.SIMPLEAGGREGATEFUNCTION: 211>, <TokenType.TDIGEST: 212>, <TokenType.UNKNOWN: 213>, <TokenType.VECTOR: 214>, <TokenType.DYNAMIC: 215>, <TokenType.VOID: 216>, <TokenType.ALL: 219>, <TokenType.ANTI: 220>, <TokenType.ANY: 221>, <TokenType.APPLY: 222>, <TokenType.ARRAY: 223>, <TokenType.ASC: 224>, <TokenType.ASOF: 225>, <TokenType.ATTACH: 226>, <TokenType.AUTO_INCREMENT: 227>, <TokenType.BEGIN: 228>, <TokenType.CACHE: 231>, <TokenType.CASE: 232>, <TokenType.COLLATE: 235>, <TokenType.COMMAND: 236>, <TokenType.COMMENT: 237>, <TokenType.COMMIT: 238>, <TokenType.CONSTRAINT: 240>, <TokenType.COPY: 241>, <TokenType.CUBE: 244>, <TokenType.CURRENT_DATE: 245>, <TokenType.CURRENT_DATETIME: 246>, <TokenType.CURRENT_SCHEMA: 247>, <TokenType.CURRENT_TIME: 248>, <TokenType.CURRENT_TIMESTAMP: 249>, <TokenType.CURRENT_USER: 250>, <TokenType.CURRENT_ROLE: 252>, <TokenType.CURRENT_CATALOG: 253>, <TokenType.DEFAULT: 255>, <TokenType.DELETE: 256>, <TokenType.DESC: 257>, <TokenType.DESCRIBE: 258>, <TokenType.DETACH: 259>, <TokenType.DICTIONARY: 260>, <TokenType.DIV: 263>, <TokenType.END: 266>, <TokenType.ESCAPE: 267>, <TokenType.EXCEPT: 268>, <TokenType.EXECUTE: 269>, <TokenType.EXISTS: 270>, <TokenType.FALSE: 271>, <TokenType.FILE: 273>, <TokenType.FILE_FORMAT: 274>, <TokenType.FILTER: 275>, <TokenType.FINAL: 276>, <TokenType.FIRST: 277>, <TokenType.FOREIGN_KEY: 280>, <TokenType.FORMAT: 281>, <TokenType.FULL: 283>, <TokenType.FUNCTION: 284>, <TokenType.GET: 285>, <TokenType.INDEX: 296>, <TokenType.INTEGRATION: 301>, <TokenType.INTERVAL: 303>, <TokenType.IS: 307>, <TokenType.ISNULL: 308>, <TokenType.KEEP: 311>, <TokenType.KILL: 313>, <TokenType.LEFT: 316>, <TokenType.LIMIT: 318>, <TokenType.LIST: 319>, <TokenType.LOAD: 320>, <TokenType.LOCK: 321>, <TokenType.MAP: 322>, <TokenType.MATCH: 323>, <TokenType.MATCH_CONDITION: 324>, <TokenType.MERGE: 327>, <TokenType.MODEL: 329>, <TokenType.NATURAL: 330>, <TokenType.NEXT: 331>, <TokenType.NOTHING: 332>, <TokenType.NULL: 334>, <TokenType.OBJECT_IDENTIFIER: 335>, <TokenType.OFFSET: 336>, <TokenType.OPERATOR: 339>, <TokenType.ORDINALITY: 343>, <TokenType.INOUT: 345>, <TokenType.OVER: 347>, <TokenType.OVERLAPS: 348>, <TokenType.OVERWRITE: 349>, <TokenType.PACKAGE: 350>, <TokenType.PARTITION: 351>, <TokenType.PERCENT: 353>, <TokenType.PIVOT: 354>, <TokenType.POLICY: 356>, <TokenType.POOL: 357>, <TokenType.PRAGMA: 359>, <TokenType.PROCEDURE: 362>, <TokenType.PSEUDO_TYPE: 364>, <TokenType.PUT: 365>, <TokenType.RANGE: 369>, <TokenType.RECURSIVE: 370>, <TokenType.REFRESH: 371>, <TokenType.RENAME: 372>, <TokenType.REPLACE: 373>, <TokenType.REFERENCES: 376>, <TokenType.RIGHT: 377>, <TokenType.ROLE: 379>, <TokenType.ROLLUP: 381>, <TokenType.ROW: 382>, <TokenType.ROWS: 383>, <TokenType.RULE: 384>, <TokenType.SEMI: 386>, <TokenType.SEQUENCE: 388>, <TokenType.SET: 390>, <TokenType.SETTINGS: 391>, <TokenType.SHOW: 392>, <TokenType.SOME: 394>, <TokenType.STORAGE_INTEGRATION: 399>, <TokenType.STRAIGHT_JOIN: 400>, <TokenType.STRUCT: 401>, <TokenType.TAG: 404>, <TokenType.TEMPORARY: 405>, <TokenType.TOP: 406>, <TokenType.TRUE: 408>, <TokenType.TRUNCATE: 409>, <TokenType.TRIGGER: 410>, <TokenType.TYPE: 411>, <TokenType.UNNEST: 414>, <TokenType.UNPIVOT: 415>, <TokenType.UPDATE: 416>, <TokenType.USE: 417>, <TokenType.VIEW: 421>, <TokenType.SEMANTIC_VIEW: 422>, <TokenType.VOLATILE: 423>, <TokenType.VOLUME: 424>, <TokenType.WINDOW: 427>, <TokenType.UNIQUE: 429>, <TokenType.SINK: 436>, <TokenType.SOURCE: 437>, <TokenType.ANALYZE: 438>, <TokenType.NAMESPACE: 439>, <TokenType.EXPORT: 440>}
NO_PAREN_FUNCTIONS =
{<TokenType.CURRENT_DATE: 245>: <class 'sqlglot.expressions.temporal.CurrentDate'>, <TokenType.CURRENT_DATETIME: 246>: <class 'sqlglot.expressions.temporal.CurrentDate'>, <TokenType.CURRENT_TIME: 248>: <class 'sqlglot.expressions.temporal.Localtime'>, <TokenType.CURRENT_TIMESTAMP: 249>: <class 'sqlglot.expressions.temporal.CurrentTimestamp'>, <TokenType.CURRENT_USER: 250>: <class 'sqlglot.expressions.functions.CurrentUser'>, <TokenType.CURRENT_ROLE: 252>: <class 'sqlglot.expressions.functions.CurrentRole'>, <TokenType.LOCALTIME: 178>: <class 'sqlglot.expressions.temporal.Localtime'>, <TokenType.LOCALTIMESTAMP: 179>: <class 'sqlglot.expressions.temporal.Localtimestamp'>}
RANGE_PARSERS =
{<TokenType.AT_GT: 55>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.BETWEEN: 229>: <function Parser.<lambda>>, <TokenType.GLOB: 286>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.ILIKE: 294>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.IN: 295>: <function Parser.<lambda>>, <TokenType.IRLIKE: 306>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.IS: 307>: <function Parser.<lambda>>, <TokenType.LIKE: 317>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.LT_AT: 54>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.OVERLAPS: 348>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.RLIKE: 378>: <function SnowflakeParser.<lambda>>, <TokenType.SIMILAR_TO: 393>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.FOR: 278>: <function Parser.<lambda>>, <TokenType.QMARK_AMP: 67>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.QMARK_PIPE: 68>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.HASH_DASH: 69>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.ADJACENT: 64>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.OPERATOR: 339>: <function Parser.<lambda>>, <TokenType.AMP_LT: 62>: <function binary_range_parser.<locals>._parse_binary_range>, <TokenType.AMP_GT: 63>: <function binary_range_parser.<locals>._parse_binary_range>}
FUNCTIONS =
{'AI_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.AIAgg'>>, 'AI_CLASSIFY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.AIClassify'>>, 'AI_EMBED': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.AIEmbed'>>, 'A_I_FORECAST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.AIForecast'>>, 'AI_GENERATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.AIGenerate'>>, 'AI_SIMILARITY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.AISimilarity'>>, 'AI_SUMMARIZE_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.AISummarizeAgg'>>, 'ABS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Abs'>>, 'ACOS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Acos'>>, 'ACOSH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Acosh'>>, 'ADD_MONTHS': <function SnowflakeParser.<lambda>>, 'AND': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.And'>>, 'ANONYMOUS_AGG_FUNC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.AnonymousAggFunc'>>, 'ANY_VALUE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.AnyValue'>>, 'APPLY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.Apply'>>, 'APPROX_DISTINCT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.ApproxDistinct'>>, 'APPROX_COUNT_DISTINCT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.ApproxDistinct'>>, 'APPROX_PERCENTILE_ACCUMULATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproxPercentileAccumulate'>>, 'APPROX_PERCENTILE_COMBINE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproxPercentileCombine'>>, 'APPROX_PERCENTILE_ESTIMATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproxPercentileEstimate'>>, 'APPROX_QUANTILE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproxQuantile'>>, 'APPROX_QUANTILES': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproxQuantiles'>>, 'APPROX_TOP_K': <function _build_approx_top_k>, 'APPROX_TOP_K_ACCUMULATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproxTopKAccumulate'>>, 'APPROX_TOP_K_COMBINE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproxTopKCombine'>>, 'APPROX_TOP_K_ESTIMATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproxTopKEstimate'>>, 'APPROX_TOP_SUM': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproxTopSum'>>, 'APPROXIMATE_SIMILARITY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproximateSimilarity'>>, 'APPROXIMATE_JACCARD_INDEX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproximateSimilarity'>>, 'ARG_MAX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ArgMax'>>, 'ARGMAX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ArgMax'>>, 'MAX_BY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ArgMax'>>, 'ARG_MIN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ArgMin'>>, 'ARGMIN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ArgMin'>>, 'MIN_BY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ArgMin'>>, 'ARRAY': <function Parser.<lambda>>, 'ARRAY_AGG': <function Parser.<lambda>>, 'ARRAY_ALL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayAll'>>, 'ARRAY_ANY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayAny'>>, 'ARRAY_APPEND': <function build_array_append>, 'ARRAY_COMPACT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayCompact'>>, 'ARRAY_CONCAT': <function build_array_concat>, 'ARRAY_CAT': <function build_array_concat>, 'ARRAY_CONCAT_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ArrayConcatAgg'>>, 'ARRAY_CONSTRUCT_COMPACT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayConstructCompact'>>, 'ARRAY_CONTAINS': <function SnowflakeParser.<lambda>>, 'ARRAY_HAS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayContains'>>, 'ARRAY_CONTAINS_ALL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayContainsAll'>>, 'ARRAY_HAS_ALL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayContainsAll'>>, 'ARRAY_DISTINCT': <function SnowflakeParser.<lambda>>, 'ARRAY_EXCEPT': <function SnowflakeParser.<lambda>>, 'FILTER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayFilter'>>, 'ARRAY_FILTER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayFilter'>>, 'ARRAY_FIRST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayFirst'>>, 'ARRAY_INSERT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayInsert'>>, 'ARRAY_INTERSECT': <function Parser.<lambda>>, 'ARRAY_INTERSECTION': <function SnowflakeParser.<lambda>>, 'ARRAY_LAST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayLast'>>, 'ARRAY_MAX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayMax'>>, 'ARRAY_MIN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayMin'>>, 'ARRAY_OVERLAPS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayOverlaps'>>, 'ARRAY_POSITION': <function SnowflakeParser.<lambda>>, 'ARRAY_PREPEND': <function build_array_prepend>, 'ARRAY_REMOVE': <function build_array_remove>, 'ARRAY_REMOVE_AT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayRemoveAt'>>, 'ARRAY_REVERSE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayReverse'>>, 'ARRAY_SIZE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArraySize'>>, 'ARRAY_LENGTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArraySize'>>, 'ARRAY_SLICE': <function SnowflakeParser.<lambda>>, 'ARRAY_SORT': <function _build_array_sort>, 'ARRAY_SUM': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArraySum'>>, 'ARRAY_TO_STRING': <function SnowflakeParser.<lambda>>, 'ARRAY_JOIN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArrayToString'>>, 'ARRAY_UNION_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ArrayUnionAgg'>>, 'ARRAY_UNIQUE_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ArrayUniqueAgg'>>, 'ARRAYS_ZIP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ArraysZip'>>, 'ASCII': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Ascii'>>, 'ASIN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Asin'>>, 'ASINH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Asinh'>>, 'ATAN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Atan'>>, 'ATAN2': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Atan2'>>, 'ATANH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Atanh'>>, 'AVG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Avg'>>, 'BASE64_DECODE_BINARY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Base64DecodeBinary'>>, 'BASE64_DECODE_STRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Base64DecodeString'>>, 'BASE64_ENCODE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Base64Encode'>>, 'BIT_LENGTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.BitLength'>>, 'BITMAP_BIT_POSITION': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitmapBitPosition'>>, 'BITMAP_BUCKET_NUMBER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitmapBucketNumber'>>, 'BITMAP_CONSTRUCT_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitmapConstructAgg'>>, 'BITMAP_COUNT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitmapCount'>>, 'BITMAP_OR_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitmapOrAgg'>>, 'BITWISE_AND_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseAndAgg'>>, 'BITWISE_COUNT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseCount'>>, 'BITWISE_OR_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseOrAgg'>>, 'BITWISE_XOR_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseXorAgg'>>, 'BOOLAND': <function SnowflakeParser.<lambda>>, 'BOOLNOT': <function SnowflakeParser.<lambda>>, 'BOOLOR': <function SnowflakeParser.<lambda>>, 'BOOLXOR_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BoolxorAgg'>>, 'BYTE_LENGTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ByteLength'>>, 'CASE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Case'>>, 'CAST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Cast'>>, 'CAST_TO_STR_TYPE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CastToStrType'>>, 'CBRT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Cbrt'>>, 'CEIL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Ceil'>>, 'CEILING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Ceil'>>, 'CHECK_JSON': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.CheckJson'>>, 'CHECK_XML': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CheckXml'>>, 'CHR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Chr'>>, 'CHAR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Chr'>>, 'CITY_HASH64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.CityHash64'>>, 'COALESCE': <function build_coalesce>, 'IFNULL': <function build_coalesce>, 'NVL': <function build_coalesce>, 'CODE_POINTS_TO_BYTES': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.CodePointsToBytes'>>, 'CODE_POINTS_TO_STRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.CodePointsToString'>>, 'COLLATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Collate'>>, 'COLLATION': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Collation'>>, 'COLUMNS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Columns'>>, 'COMBINED_AGG_FUNC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.CombinedAggFunc'>>, 'COMBINED_PARAMETERIZED_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.CombinedParameterizedAgg'>>, 'COMPRESS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Compress'>>, 'CONCAT': <function Parser.<lambda>>, 'CONCAT_WS': <function Parser.<lambda>>, 'CONNECT_BY_ROOT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.ConnectByRoot'>>, 'CONTAINS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Contains'>>, 'CONVERT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Convert'>>, 'CONVERT_TIMEZONE': <function build_convert_timezone>, 'CONVERT_TO_CHARSET': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ConvertToCharset'>>, 'CORR': <function SnowflakeParser.<lambda>>, 'COS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Cos'>>, 'COSH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Cosh'>>, 'COSINE_DISTANCE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.CosineDistance'>>, 'COT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Cot'>>, 'COTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Coth'>>, 'COUNT': <function Parser.<lambda>>, 'COUNT_IF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.CountIf'>>, 'COUNTIF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.CountIf'>>, 'COVAR_POP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.CovarPop'>>, 'COVAR_SAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.CovarSamp'>>, 'CSC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Csc'>>, 'CSCH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Csch'>>, 'CUME_DIST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.CumeDist'>>, 'CURRENT_ACCOUNT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentAccount'>>, 'CURRENT_ACCOUNT_NAME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentAccountName'>>, 'CURRENT_AVAILABLE_ROLES': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentAvailableRoles'>>, 'CURRENT_CATALOG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentCatalog'>>, 'CURRENT_CLIENT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentClient'>>, 'CURRENT_DATABASE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentDatabase'>>, 'CURRENT_DATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.CurrentDate'>>, 'CURRENT_DATETIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.CurrentDatetime'>>, 'CURRENT_IP_ADDRESS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentIpAddress'>>, 'CURRENT_ORGANIZATION_NAME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentOrganizationName'>>, 'CURRENT_ORGANIZATION_USER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentOrganizationUser'>>, 'CURRENT_REGION': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentRegion'>>, 'CURRENT_ROLE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentRole'>>, 'CURRENT_ROLE_TYPE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentRoleType'>>, 'CURRENT_SCHEMA': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentSchema'>>, 'CURRENT_SCHEMAS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentSchemas'>>, 'CURRENT_SECONDARY_ROLES': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentSecondaryRoles'>>, 'CURRENT_SESSION': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentSession'>>, 'CURRENT_STATEMENT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentStatement'>>, 'CURRENT_TIME': <function SnowflakeParser.<lambda>>, 'CURRENT_TIMESTAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.CurrentTimestamp'>>, 'CURRENT_TIMESTAMP_L_T_Z': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.CurrentTimestampLTZ'>>, 'CURRENT_TIMEZONE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.CurrentTimezone'>>, 'CURRENT_TRANSACTION': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentTransaction'>>, 'CURRENT_USER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentUser'>>, 'CURRENT_USER_ID': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentUserId'>>, 'CURRENT_VERSION': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentVersion'>>, 'CURRENT_WAREHOUSE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.CurrentWarehouse'>>, 'DATE': <function _build_datetime.<locals>._builder>, 'DATE_ADD': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DateAdd'>>, 'DATE_BIN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DateBin'>>, 'DATEDIFF': <function SnowflakeParser.<lambda>>, 'DATE_DIFF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DateDiff'>>, 'DATE_FROM_PARTS': <function _build_date_from_parts>, 'DATEFROMPARTS': <function _build_date_from_parts>, 'DATE_FROM_UNIX_DATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DateFromUnixDate'>>, 'DATE_STR_TO_DATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DateStrToDate'>>, 'DATE_SUB': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DateSub'>>, 'DATE_TO_DATE_STR': <function Parser.<lambda>>, 'DATE_TO_DI': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DateToDi'>>, 'DATE_TRUNC': <function _date_trunc_to_time>, 'DATETIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Datetime'>>, 'DATETIME_ADD': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DatetimeAdd'>>, 'DATETIME_DIFF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DatetimeDiff'>>, 'DATETIME_SUB': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DatetimeSub'>>, 'DATETIME_TRUNC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DatetimeTrunc'>>, 'DAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Day'>>, 'DAY_OF_MONTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DayOfMonth'>>, 'DAYOFMONTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DayOfMonth'>>, 'DAY_OF_WEEK': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DayOfWeek'>>, 'DAYOFWEEK': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DayOfWeek'>>, 'DAYOFWEEK_ISO': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DayOfWeekIso'>>, 'ISODOW': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DayOfWeekIso'>>, 'DAY_OF_YEAR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DayOfYear'>>, 'DAYOFYEAR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DayOfYear'>>, 'DAYNAME': <function SnowflakeParser.<lambda>>, 'DECODE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Decode'>>, 'DECODE_CASE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.DecodeCase'>>, 'DECOMPRESS_BINARY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.DecompressBinary'>>, 'DECOMPRESS_STRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.DecompressString'>>, 'DECRYPT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Decrypt'>>, 'DECRYPT_RAW': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.DecryptRaw'>>, 'DEGREES': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Degrees'>>, 'DENSE_RANK': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.DenseRank'>>, 'DI_TO_DATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DiToDate'>>, 'DOT_PRODUCT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.DotProduct'>>, 'ELT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Elt'>>, 'ENCODE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Encode'>>, 'ENCRYPT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Encrypt'>>, 'ENCRYPT_RAW': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.EncryptRaw'>>, 'ENDS_WITH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.EndsWith'>>, 'ENDSWITH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.EndsWith'>>, 'EQUAL_NULL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.EqualNull'>>, 'EUCLIDEAN_DISTANCE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.EuclideanDistance'>>, 'EXISTS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Exists'>>, 'EXP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Exp'>>, 'EXPLODE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.Explode'>>, 'EXPLODING_GENERATE_SERIES': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ExplodingGenerateSeries'>>, 'EXTRACT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Extract'>>, 'FACTORIAL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Factorial'>>, 'FARM_FINGERPRINT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.FarmFingerprint'>>, 'FARMFINGERPRINT64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.FarmFingerprint'>>, 'FEATURES_AT_TIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.FeaturesAtTime'>>, 'FIRST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.First'>>, 'FIRST_VALUE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.FirstValue'>>, 'FLATTEN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.Explode'>>, 'FLOAT64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Float64'>>, 'FLOOR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Floor'>>, 'FORMAT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Format'>>, 'FROM_BASE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.FromBase'>>, 'FROM_BASE32': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.FromBase32'>>, 'FROM_BASE64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.FromBase64'>>, 'FROM_ISO8601_TIMESTAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.FromISO8601Timestamp'>>, 'GAP_FILL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.GapFill'>>, 'GENERATE_BOOL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.GenerateBool'>>, 'GENERATE_DATE_ARRAY': <function Parser.<lambda>>, 'GENERATE_DOUBLE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.GenerateDouble'>>, 'GENERATE_EMBEDDING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.GenerateEmbedding'>>, 'GENERATE_INT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.GenerateInt'>>, 'GENERATE_SERIES': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.GenerateSeries'>>, 'GENERATE_TABLE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.GenerateTable'>>, 'GENERATE_TEXT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.GenerateText'>>, 'GENERATE_TIMESTAMP_ARRAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.GenerateTimestampArray'>>, 'GENERATOR': <function _build_generator>, 'GET_EXTRACT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.GetExtract'>>, 'GET_IGNORE_CASE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.GetIgnoreCase'>>, 'GETBIT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Getbit'>>, 'GET_BIT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Getbit'>>, 'GREATEST': <function Parser.<lambda>>, 'GROUP_CONCAT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.GroupConcat'>>, 'GROUPING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Grouping'>>, 'GROUPING_ID': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.GroupingId'>>, 'HASH_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.HashAgg'>>, 'HEX': <function build_hex>, 'HEX_DECODE_STRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.HexDecodeString'>>, 'HLL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.Hll'>>, 'HOST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Host'>>, 'HOUR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Hour'>>, 'IF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.If'>>, 'IIF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.If'>>, 'INITCAP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Initcap'>>, 'INLINE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.Inline'>>, 'INT64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Int64'>>, 'IS_ARRAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.IsArray'>>, 'IS_ASCII': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.IsAscii'>>, 'IS_INF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.IsInf'>>, 'ISINF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.IsInf'>>, 'IS_NAN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.IsNan'>>, 'ISNAN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.IsNan'>>, 'IS_NULL_VALUE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.IsNullValue'>>, 'J_S_O_N_ARRAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONArray'>>, 'J_S_O_N_ARRAY_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONArrayAgg'>>, 'JSON_ARRAY_APPEND': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONArrayAppend'>>, 'JSON_ARRAY_CONTAINS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONArrayContains'>>, 'JSON_ARRAY_INSERT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONArrayInsert'>>, 'JSONB_CONTAINS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONBContains'>>, 'J_S_O_N_B_CONTAINS_ALL_TOP_KEYS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONBContainsAllTopKeys'>>, 'J_S_O_N_B_CONTAINS_ANY_TOP_KEYS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONBContainsAnyTopKeys'>>, 'J_S_O_N_B_DELETE_AT_PATH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONBDeleteAtPath'>>, 'JSONB_EXISTS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONBExists'>>, 'JSONB_EXTRACT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONBExtract'>>, 'JSONB_EXTRACT_SCALAR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONBExtractScalar'>>, 'J_S_O_N_B_OBJECT_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONBObjectAgg'>>, 'J_S_O_N_BOOL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONBool'>>, 'J_S_O_N_CAST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.JSONCast'>>, 'J_S_O_N_EXISTS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONExists'>>, 'JSON_EXTRACT': <function build_extract_json_with_path.<locals>._builder>, 'JSON_EXTRACT_ARRAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONExtractArray'>>, 'JSON_EXTRACT_SCALAR': <function build_extract_json_with_path.<locals>._builder>, 'JSON_FORMAT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONFormat'>>, 'JSON_KEYS': <function Parser.<lambda>>, 'J_S_O_N_KEYS_AT_DEPTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONKeysAtDepth'>>, 'J_S_O_N_OBJECT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONObject'>>, 'J_S_O_N_OBJECT_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONObjectAgg'>>, 'JSON_REMOVE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONRemove'>>, 'JSON_SET': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONSet'>>, 'JSON_STRIP_NULLS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONStripNulls'>>, 'J_S_O_N_TABLE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONTable'>>, 'JSON_TYPE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONType'>>, 'J_S_O_N_VALUE_ARRAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.query.JSONValueArray'>>, 'JAROWINKLER_SIMILARITY': <function SnowflakeParser.<lambda>>, 'JUSTIFY_DAYS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.JustifyDays'>>, 'JUSTIFY_HOURS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.JustifyHours'>>, 'JUSTIFY_INTERVAL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.JustifyInterval'>>, 'KURTOSIS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Kurtosis'>>, 'LAG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Lag'>>, 'LAST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Last'>>, 'LAST_DAY': <function SnowflakeParser.<lambda>>, 'LAST_DAY_OF_MONTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.LastDay'>>, 'LAST_VALUE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.LastValue'>>, 'LAX_BOOL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.LaxBool'>>, 'LAX_FLOAT64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.LaxFloat64'>>, 'LAX_INT64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.LaxInt64'>>, 'LAX_STRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.LaxString'>>, 'LEAD': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Lead'>>, 'LEAST': <function Parser.<lambda>>, 'LEFT': <function SnowflakeParser.<lambda>>, 'LENGTH': <function SnowflakeParser.<lambda>>, 'LEN': <function SnowflakeParser.<lambda>>, 'CHAR_LENGTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Length'>>, 'CHARACTER_LENGTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Length'>>, 'LEVENSHTEIN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Levenshtein'>>, 'LIST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.List'>>, 'LN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Ln'>>, 'LOCALTIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Localtime'>>, 'LOCALTIMESTAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.CurrentTimestamp'>>, 'LOG': <function build_logarithm>, 'LOGICAL_AND': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.LogicalAnd'>>, 'BOOL_AND': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.LogicalAnd'>>, 'BOOLAND_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.LogicalAnd'>>, 'LOGICAL_OR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.LogicalOr'>>, 'BOOL_OR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.LogicalOr'>>, 'BOOLOR_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.LogicalOr'>>, 'LOWER': <function build_lower>, 'LCASE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Lower'>>, 'LOWER_HEX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.LowerHex'>>, 'MD5': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.MD5'>>, 'MD5_DIGEST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.MD5Digest'>>, 'M_D5_NUMBER_LOWER64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.MD5NumberLower64'>>, 'M_D5_NUMBER_UPPER64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.MD5NumberUpper64'>>, 'M_L_FORECAST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.MLForecast'>>, 'M_L_TRANSLATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.MLTranslate'>>, 'MAKE_INTERVAL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.MakeInterval'>>, 'MANHATTAN_DISTANCE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.ManhattanDistance'>>, 'MAP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.Map'>>, 'MAP_CAT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.MapCat'>>, 'MAP_CONTAINS_KEY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.MapContainsKey'>>, 'MAP_DELETE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.MapDelete'>>, 'MAP_FROM_ENTRIES': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.MapFromEntries'>>, 'MAP_INSERT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.MapInsert'>>, 'MAP_KEYS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.MapKeys'>>, 'MAP_PICK': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.MapPick'>>, 'MAP_SIZE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.MapSize'>>, 'MATCH_AGAINST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.MatchAgainst'>>, 'MAX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Max'>>, 'MEDIAN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Median'>>, 'MIN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Min'>>, 'MINHASH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Minhash'>>, 'MINHASH_COMBINE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.MinhashCombine'>>, 'MINUTE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Minute'>>, 'MODE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Mode'>>, 'MONTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Month'>>, 'MONTHNAME': <function SnowflakeParser.<lambda>>, 'MONTHS_BETWEEN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.MonthsBetween'>>, 'NET_FUNC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.NetFunc'>>, 'NEXT_DAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.NextDay'>>, 'NEXT_VALUE_FOR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.ddl.NextValueFor'>>, 'NORMAL': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Normal'>>, 'NORMALIZE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Normalize'>>, 'NTH_VALUE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.NthValue'>>, 'NTILE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Ntile'>>, 'NULLIF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Nullif'>>, 'NUMBER_TO_STR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.NumberToStr'>>, 'NVL2': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Nvl2'>>, 'OBJECT_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ObjectAgg'>>, 'OBJECT_ID': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.ObjectId'>>, 'OBJECT_INSERT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.ObjectInsert'>>, 'OBJECT_TRANSFORM': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.ObjectTransform'>>, 'OPEN_J_S_O_N': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.OpenJSON'>>, 'OR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.Or'>>, 'OVERLAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Overlay'>>, 'PAD': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Pad'>>, 'PARAMETERIZED_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.ParameterizedAgg'>>, 'PARSE_BIGNUMERIC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ParseBignumeric'>>, 'PARSE_DATETIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.ParseDatetime'>>, 'PARSE_IP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.ParseIp'>>, 'PARSE_JSON': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.ParseJSON'>>, 'JSON_PARSE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.ParseJSON'>>, 'PARSE_NUMERIC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ParseNumeric'>>, 'PARSE_TIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.ParseTime'>>, 'PARSE_URL': <function SnowflakeParser.<lambda>>, 'PERCENT_RANK': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.PercentRank'>>, 'PERCENTILE_CONT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.PercentileCont'>>, 'PERCENTILE_DISC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.PercentileDisc'>>, 'PI': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Pi'>>, 'POSEXPLODE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.Posexplode'>>, 'POSEXPLODE_OUTER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.PosexplodeOuter'>>, 'POWER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.Pow'>>, 'POW': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.Pow'>>, 'PREVIOUS_DAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.PreviousDay'>>, 'QUANTILE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Quantile'>>, 'QUARTER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Quarter'>>, 'RADIANS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Radians'>>, 'RAND': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Rand'>>, 'RANDOM': <function SnowflakeParser.<lambda>>, 'RANDN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Randn'>>, 'RANDSTR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Randstr'>>, 'RANGE_BUCKET': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.RangeBucket'>>, 'RANGE_N': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.RangeN'>>, 'RANK': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Rank'>>, 'READ_CSV': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.ReadCSV'>>, 'READ_PARQUET': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.ReadParquet'>>, 'REDUCE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.Reduce'>>, 'REG_DOMAIN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.RegDomain'>>, 'REGEXP_COUNT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.RegexpCount'>>, 'REGEXP_EXTRACT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.RegexpExtract'>>, 'REGEXP_EXTRACT_ALL': <function _build_regexp_extract.<locals>._builder>, 'REGEXP_FULL_MATCH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.RegexpFullMatch'>>, 'REGEXP_I_LIKE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.RegexpILike'>>, 'REGEXP_INSTR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.RegexpInstr'>>, 'REGEXP_LIKE': <function _build_regexp_like>, 'REGEXP_REPLACE': <function _build_regexp_replace>, 'REGEXP_SPLIT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.RegexpSplit'>>, 'REGR_AVGX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrAvgx'>>, 'REGR_AVGY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrAvgy'>>, 'REGR_COUNT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrCount'>>, 'REGR_INTERCEPT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrIntercept'>>, 'REGR_R2': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrR2'>>, 'REGR_SLOPE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrSlope'>>, 'REGR_SXX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrSxx'>>, 'REGR_SXY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrSxy'>>, 'REGR_SYY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrSyy'>>, 'REGR_VALX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrValx'>>, 'REGR_VALY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RegrValy'>>, 'REPEAT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Repeat'>>, 'REPLACE': <function build_replace_with_optional_replacement>, 'REVERSE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Reverse'>>, 'RIGHT': <function SnowflakeParser.<lambda>>, 'ROUND': <function _build_round>, 'ROW_NUMBER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.RowNumber'>>, 'RTRIMMED_LENGTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.RtrimmedLength'>>, 'SHA': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SHA'>>, 'SHA1': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SHA'>>, 'S_H_A1_DIGEST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SHA1Digest'>>, 'SHA2': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SHA2'>>, 'S_H_A2_DIGEST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SHA2Digest'>>, 'SAFE_ADD': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.SafeAdd'>>, 'SAFE_CONVERT_BYTES_TO_STRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SafeConvertBytesToString'>>, 'SAFE_DIVIDE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.SafeDivide'>>, 'SAFE_FUNC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.SafeFunc'>>, 'SAFE_MULTIPLY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.SafeMultiply'>>, 'SAFE_NEGATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.SafeNegate'>>, 'SAFE_SUBTRACT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.SafeSubtract'>>, 'SEARCH': <function _build_search>, 'SEARCH_IP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SearchIp'>>, 'SEC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Sec'>>, 'SECH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Sech'>>, 'SECOND': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Second'>>, 'SEQ1': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Seq1'>>, 'SEQ2': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Seq2'>>, 'SEQ4': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Seq4'>>, 'SEQ8': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Seq8'>>, 'SESSION_USER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.SessionUser'>>, 'SIGN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Sign'>>, 'SIGNUM': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Sign'>>, 'SIN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Sin'>>, 'SINH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Sinh'>>, 'SKEWNESS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Skewness'>>, 'SORT_ARRAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.SortArray'>>, 'SOUNDEX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Soundex'>>, 'SOUNDEX_P123': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SoundexP123'>>, 'SPACE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Space'>>, 'SPLIT': <function SnowflakeParser.<lambda>>, 'SPLIT_PART': <function SnowflakeParser.<lambda>>, 'SQRT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Sqrt'>>, 'ST_DISTANCE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.StDistance'>>, 'ST_POINT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.StPoint'>>, 'ST_MAKEPOINT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.StPoint'>>, 'STANDARD_HASH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.StandardHash'>>, 'STAR_MAP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.StarMap'>>, 'STARTS_WITH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.StartsWith'>>, 'STARTSWITH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.StartsWith'>>, 'STDDEV': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Stddev'>>, 'STDEV': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Stddev'>>, 'STDDEV_POP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.StddevPop'>>, 'STDDEV_SAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Stddev'>>, 'STR_POSITION': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.StrPosition'>>, 'STR_TO_DATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.StrToDate'>>, 'STR_TO_MAP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.StrToMap'>>, 'STR_TO_TIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.StrToTime'>>, 'STR_TO_UNIX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.StrToUnix'>>, 'STRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.String'>>, 'STRING_TO_ARRAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.StringToArray'>>, 'SPLIT_BY_STRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.StringToArray'>>, 'STRIP_NULL_VALUE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.StripNullValue'>>, 'STRTOK': <function SnowflakeParser.<lambda>>, 'STRTOK_TO_ARRAY': <function SnowflakeParser.<lambda>>, 'STRUCT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.Struct'>>, 'STRUCT_EXTRACT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.StructExtract'>>, 'STUFF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Stuff'>>, 'INSERT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Stuff'>>, 'SUBSTRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Substring'>>, 'SUBSTR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Substring'>>, 'SUBSTRING_INDEX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SubstringIndex'>>, 'SUM': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Sum'>>, 'SYSTIMESTAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.CurrentTimestamp'>>, 'TAN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Tan'>>, 'TANH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.Tanh'>>, 'TIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Time'>>, 'TIME_ADD': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeAdd'>>, 'TIME_DIFF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeDiff'>>, 'TIME_FROM_PARTS': <function SnowflakeParser.<lambda>>, 'TIMEFROMPARTS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeFromParts'>>, 'TIME_SLICE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeSlice'>>, 'TIME_STR_TO_DATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeStrToDate'>>, 'TIME_STR_TO_TIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeStrToTime'>>, 'TIME_STR_TO_UNIX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeStrToUnix'>>, 'TIME_SUB': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeSub'>>, 'TIME_TO_STR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeToStr'>>, 'TIME_TO_TIME_STR': <function Parser.<lambda>>, 'TIME_TO_UNIX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeToUnix'>>, 'TIME_TRUNC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimeTrunc'>>, 'TIMESTAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Timestamp'>>, 'TIMESTAMP_ADD': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimestampAdd'>>, 'TIMESTAMPDIFF': <function SnowflakeParser.<lambda>>, 'TIMESTAMP_DIFF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimestampDiff'>>, 'TIMESTAMP_FROM_PARTS': <function _build_timestamp_from_parts>, 'TIMESTAMPFROMPARTS': <function _build_timestamp_from_parts>, 'TIMESTAMP_LTZ_FROM_PARTS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimestampLtzFromParts'>>, 'TIMESTAMPLTZFROMPARTS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimestampLtzFromParts'>>, 'TIMESTAMP_SUB': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimestampSub'>>, 'TIMESTAMP_TRUNC': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimestampTrunc'>>, 'TIMESTAMP_TZ_FROM_PARTS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimestampTzFromParts'>>, 'TIMESTAMPTZFROMPARTS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TimestampTzFromParts'>>, 'TO_ARRAY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ToArray'>>, 'TO_BASE32': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ToBase32'>>, 'TO_BASE64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ToBase64'>>, 'TO_BINARY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ToBinary'>>, 'TO_BOOLEAN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.ToBoolean'>>, 'TO_CHAR': <function build_timetostr_or_tochar>, 'TO_CODE_POINTS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ToCodePoints'>>, 'TO_DAYS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.ToDays'>>, 'TO_DECFLOAT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ToDecfloat'>>, 'TO_DOUBLE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ToDouble'>>, 'TO_FILE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ToFile'>>, 'TO_MAP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.ToMap'>>, 'TO_NUMBER': <function SnowflakeParser.<lambda>>, 'TO_VARIANT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.ToVariant'>>, 'TRANSFORM': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.Transform'>>, 'TRANSLATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Translate'>>, 'TRIM': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Trim'>>, 'TRUNC': <function SnowflakeParser.<lambda>>, 'TRUNCATE': <function SnowflakeParser.<lambda>>, 'TRY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Try'>>, 'TRY_BASE64_DECODE_BINARY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.TryBase64DecodeBinary'>>, 'TRY_BASE64_DECODE_STRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.TryBase64DecodeString'>>, 'TRY_CAST': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.TryCast'>>, 'TRY_HEX_DECODE_BINARY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.TryHexDecodeBinary'>>, 'TRY_HEX_DECODE_STRING': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.TryHexDecodeString'>>, 'TRY_TO_DECFLOAT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.TryToDecfloat'>>, 'TS_OR_DI_TO_DI': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TsOrDiToDi'>>, 'TS_OR_DS_ADD': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TsOrDsAdd'>>, 'TS_OR_DS_DIFF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TsOrDsDiff'>>, 'TS_OR_DS_TO_DATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TsOrDsToDate'>>, 'TS_OR_DS_TO_DATE_STR': <function Parser.<lambda>>, 'TS_OR_DS_TO_DATETIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TsOrDsToDatetime'>>, 'TS_OR_DS_TO_TIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TsOrDsToTime'>>, 'TS_OR_DS_TO_TIMESTAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.TsOrDsToTimestamp'>>, 'TYPEOF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.Typeof'>>, 'UNHEX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Unhex'>>, 'UNICODE': <function SnowflakeParser.<lambda>>, 'UNIFORM': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Uniform'>>, 'UNIX_DATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.UnixDate'>>, 'UNIX_MICROS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.UnixMicros'>>, 'UNIX_MILLIS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.UnixMillis'>>, 'UNIX_SECONDS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.UnixSeconds'>>, 'UNIX_TO_STR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.UnixToStr'>>, 'UNIX_TO_TIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.UnixToTime'>>, 'UNIX_TO_TIME_STR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.UnixToTimeStr'>>, 'UNNEST': <function Parser.<lambda>>, 'UPPER': <function build_upper>, 'UCASE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Upper'>>, 'UTC_DATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.UtcDate'>>, 'UTC_TIME': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.UtcTime'>>, 'UTC_TIMESTAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.UtcTimestamp'>>, 'UUID': <function Parser.<lambda>>, 'GEN_RANDOM_UUID': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Uuid'>>, 'GENERATE_UUID': <function Parser.<lambda>>, 'UUID_STRING': <function Parser.<lambda>>, 'VAR_MAP': <function build_var_map>, 'VARIANCE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Variance'>>, 'VARIANCE_SAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Variance'>>, 'VAR_SAMP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Variance'>>, 'VARIANCE_POP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.VariancePop'>>, 'VAR_POP': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.VariancePop'>>, 'VECTOR_SEARCH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.VectorSearch'>>, 'WEEK': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Week'>>, 'WEEK_OF_YEAR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.WeekOfYear'>>, 'WEEKOFYEAR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Week'>>, 'WEEK_START': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.WeekStart'>>, 'WIDTH_BUCKET': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.WidthBucket'>>, 'XMLELEMENT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.XMLElement'>>, 'XMLGET': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.XMLGet'>>, 'X_M_L_TABLE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.XMLTable'>>, 'XOR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.core.Xor'>>, 'YEAR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.Year'>>, 'YEAR_OF_WEEK': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.YearOfWeek'>>, 'YEAROFWEEK': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.YearOfWeek'>>, 'YEAR_OF_WEEK_ISO': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.YearOfWeekIso'>>, 'YEAROFWEEKISO': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.YearOfWeekIso'>>, 'ZIPF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.Zipf'>>, 'EXPLODE_OUTER': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array._ExplodeOuter'>>, 'ARRAYAGG': <function Parser.<lambda>>, 'GLOB': <function Parser.<lambda>>, 'JSON_EXTRACT_PATH_TEXT': <function build_extract_json_with_path.<locals>._builder>, 'LIKE': <function build_like.<locals>._builder>, 'LOG2': <function Parser.<lambda>>, 'LOG10': <function Parser.<lambda>>, 'LPAD': <function Parser.<lambda>>, 'LEFTPAD': <function Parser.<lambda>>, 'LTRIM': <function Parser.<lambda>>, 'MOD': <function build_mod>, 'RIGHTPAD': <function Parser.<lambda>>, 'RPAD': <function Parser.<lambda>>, 'RTRIM': <function Parser.<lambda>>, 'SCOPE_RESOLUTION': <function Parser.<lambda>>, 'STRPOS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.StrPosition'>>, 'CHARINDEX': <function SnowflakeParser.<lambda>>, 'INSTR': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.StrPosition'>>, 'LOCATE': <function Parser.<lambda>>, 'TO_HEX': <function build_hex>, 'APPROX_PERCENTILE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.ApproxQuantile'>>, 'ARRAY_CONSTRUCT': <function SnowflakeParser.<lambda>>, 'ARRAY_GENERATE_RANGE': <function SnowflakeParser.<lambda>>, 'ARRAY_FLATTEN': <bound method Func.from_arg_list of <class 'sqlglot.expressions.array.Flatten'>>, 'ARRAYS_OVERLAP': <function SnowflakeParser.<lambda>>, 'BITAND': <function _build_bitwise.<locals>._builder>, 'BIT_AND': <function _build_bitwise.<locals>._builder>, 'BITNOT': <function SnowflakeParser.<lambda>>, 'BIT_NOT': <function SnowflakeParser.<lambda>>, 'BITXOR': <function _build_bitwise.<locals>._builder>, 'BIT_XOR': <function _build_bitwise.<locals>._builder>, 'BITOR': <function _build_bitwise.<locals>._builder>, 'BIT_OR': <function _build_bitwise.<locals>._builder>, 'BITSHIFTLEFT': <function _build_bitwise.<locals>._builder>, 'BIT_SHIFTLEFT': <function _build_bitwise.<locals>._builder>, 'BITSHIFTRIGHT': <function _build_bitwise.<locals>._builder>, 'BIT_SHIFTRIGHT': <function _build_bitwise.<locals>._builder>, 'BITANDAGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseAndAgg'>>, 'BITAND_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseAndAgg'>>, 'BIT_AND_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseAndAgg'>>, 'BIT_ANDAGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseAndAgg'>>, 'BITORAGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseOrAgg'>>, 'BITOR_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseOrAgg'>>, 'BIT_OR_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseOrAgg'>>, 'BIT_ORAGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseOrAgg'>>, 'BITXORAGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseXorAgg'>>, 'BITXOR_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseXorAgg'>>, 'BIT_XOR_AGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseXorAgg'>>, 'BIT_XORAGG': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.BitwiseXorAgg'>>, 'BOOLXOR': <function SnowflakeParser.<lambda>>, 'DATEADD': <function SnowflakeParser.<lambda>>, 'DAYOFWEEKISO': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.DayOfWeekIso'>>, 'DIV0': <function _build_if_from_div0>, 'DIV0NULL': <function _build_if_from_div0null>, 'EDITDISTANCE': <function SnowflakeParser.<lambda>>, 'GET': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.GetExtract'>>, 'GETDATE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.CurrentTimestamp'>>, 'GET_PATH': <function SnowflakeParser.<lambda>>, 'GREATEST_IGNORE_NULLS': <function SnowflakeParser.<lambda>>, 'LEAST_IGNORE_NULLS': <function SnowflakeParser.<lambda>>, 'HEX_DECODE_BINARY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Unhex'>>, 'HEX_ENCODE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.Hex'>>, 'IFF': <bound method Func.from_arg_list of <class 'sqlglot.expressions.functions.If'>>, 'MD5_HEX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.MD5'>>, 'MD5_BINARY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.MD5Digest'>>, 'MD5_NUMBER_LOWER64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.MD5NumberLower64'>>, 'MD5_NUMBER_UPPER64': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.MD5NumberUpper64'>>, 'NULLIFZERO': <function _build_if_from_nullifzero>, 'OBJECT_CONSTRUCT': <function SnowflakeParser.<lambda>>, 'OBJECT_KEYS': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONKeys'>>, 'OCTET_LENGTH': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.ByteLength'>>, 'REGEXP_SUBSTR': <function _build_regexp_extract.<locals>._builder>, 'REGEXP_SUBSTR_ALL': <function _build_regexp_extract.<locals>._builder>, 'RLIKE': <function _build_regexp_like>, 'SHA1_BINARY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SHA1Digest'>>, 'SHA1_HEX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SHA'>>, 'SHA2_BINARY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SHA2Digest'>>, 'SHA2_HEX': <bound method Func.from_arg_list of <class 'sqlglot.expressions.string.SHA2'>>, 'SQUARE': <function SnowflakeParser.<lambda>>, 'SYSDATE': <function SnowflakeParser.<lambda>>, 'TABLE': <function SnowflakeParser.<lambda>>, 'TIMEADD': <function SnowflakeParser.<lambda>>, 'TIMEDIFF': <function SnowflakeParser.<lambda>>, 'TIMESTAMPADD': <function SnowflakeParser.<lambda>>, 'TIMESTAMPNTZFROMPARTS': <function _build_timestamp_from_parts>, 'TIMESTAMP_NTZ_FROM_PARTS': <function _build_timestamp_from_parts>, 'TRY_DECRYPT': <function SnowflakeParser.<lambda>>, 'TRY_DECRYPT_RAW': <function SnowflakeParser.<lambda>>, 'TRY_PARSE_JSON': <function SnowflakeParser.<lambda>>, 'TRY_TO_BINARY': <function SnowflakeParser.<lambda>>, 'TRY_TO_BOOLEAN': <function SnowflakeParser.<lambda>>, 'TRY_TO_DATE': <function _build_datetime.<locals>._builder>, 'TRY_TO_DECIMAL': <function SnowflakeParser.<lambda>>, 'TRY_TO_NUMBER': <function SnowflakeParser.<lambda>>, 'TRY_TO_NUMERIC': <function SnowflakeParser.<lambda>>, 'TRY_TO_DOUBLE': <function SnowflakeParser.<lambda>>, 'TRY_TO_FILE': <function SnowflakeParser.<lambda>>, 'TRY_TO_TIME': <function _build_datetime.<locals>._builder>, 'TRY_TO_TIMESTAMP': <function _build_datetime.<locals>._builder>, 'TRY_TO_TIMESTAMP_LTZ': <function _build_datetime.<locals>._builder>, 'TRY_TO_TIMESTAMP_NTZ': <function _build_datetime.<locals>._builder>, 'TRY_TO_TIMESTAMP_TZ': <function _build_datetime.<locals>._builder>, 'TO_DATE': <function _build_datetime.<locals>._builder>, 'TO_DECIMAL': <function SnowflakeParser.<lambda>>, 'TO_NUMERIC': <function SnowflakeParser.<lambda>>, 'TO_TIME': <function _build_datetime.<locals>._builder>, 'TO_TIMESTAMP': <function _build_datetime.<locals>._builder>, 'TO_TIMESTAMP_LTZ': <function _build_datetime.<locals>._builder>, 'TO_TIMESTAMP_NTZ': <function _build_datetime.<locals>._builder>, 'TO_TIMESTAMP_TZ': <function _build_datetime.<locals>._builder>, 'TO_GEOGRAPHY': <function SnowflakeParser.<lambda>>, 'TO_GEOMETRY': <function SnowflakeParser.<lambda>>, 'TO_VARCHAR': <function build_timetostr_or_tochar>, 'TO_JSON': <bound method Func.from_arg_list of <class 'sqlglot.expressions.json.JSONFormat'>>, 'VECTOR_COSINE_SIMILARITY': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.CosineDistance'>>, 'VECTOR_INNER_PRODUCT': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.DotProduct'>>, 'VECTOR_L1_DISTANCE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.ManhattanDistance'>>, 'VECTOR_L2_DISTANCE': <bound method Func.from_arg_list of <class 'sqlglot.expressions.math.EuclideanDistance'>>, 'ZEROIFNULL': <function _build_if_from_zeroifnull>, 'ILIKE': <function build_like.<locals>._builder>, 'SKEW': <bound method Func.from_arg_list of <class 'sqlglot.expressions.aggregate.Skewness'>>, 'WEEKISO': <bound method Func.from_arg_list of <class 'sqlglot.expressions.temporal.WeekOfYear'>>}
FUNCTION_PARSERS =
{'ARG_MAX': <function Parser.<dictcomp>.<lambda>>, 'ARGMAX': <function Parser.<dictcomp>.<lambda>>, 'MAX_BY': <function Parser.<dictcomp>.<lambda>>, 'ARG_MIN': <function Parser.<dictcomp>.<lambda>>, 'ARGMIN': <function Parser.<dictcomp>.<lambda>>, 'MIN_BY': <function Parser.<dictcomp>.<lambda>>, 'CAST': <function Parser.<lambda>>, 'CEIL': <function Parser.<lambda>>, 'CONVERT': <function Parser.<lambda>>, 'CHAR': <function Parser.<lambda>>, 'CHR': <function Parser.<lambda>>, 'DECODE': <function Parser.<lambda>>, 'EXTRACT': <function Parser.<lambda>>, 'FLOOR': <function Parser.<lambda>>, 'GAP_FILL': <function Parser.<lambda>>, 'INITCAP': <function Parser.<lambda>>, 'JSON_OBJECT': <function Parser.<lambda>>, 'JSON_OBJECTAGG': <function Parser.<lambda>>, 'JSON_TABLE': <function Parser.<lambda>>, 'MATCH': <function Parser.<lambda>>, 'NORMALIZE': <function Parser.<lambda>>, 'OPENJSON': <function Parser.<lambda>>, 'OVERLAY': <function Parser.<lambda>>, 'POSITION': <function Parser.<lambda>>, 'SAFE_CAST': <function Parser.<lambda>>, 'STRING_AGG': <function Parser.<lambda>>, 'SUBSTRING': <function Parser.<lambda>>, 'TRY_CAST': <function Parser.<lambda>>, 'TRY_CONVERT': <function Parser.<lambda>>, 'XMLELEMENT': <function Parser.<lambda>>, 'XMLTABLE': <function Parser.<lambda>>, 'DATE_PART': <function SnowflakeParser.<lambda>>, 'DIRECTORY': <function SnowflakeParser.<lambda>>, 'OBJECT_CONSTRUCT_KEEP_NULL': <function SnowflakeParser.<lambda>>, 'LISTAGG': <function SnowflakeParser.<lambda>>, 'SEMANTIC_VIEW': <function SnowflakeParser.<lambda>>, 'SUBSTR': <function SnowflakeParser.<lambda>>}
TIMESTAMPS =
{<TokenType.TIMETZ: 143>, <TokenType.TIMESTAMP: 145>, <TokenType.TIMESTAMPTZ: 146>, <TokenType.TIMESTAMPLTZ: 147>, <TokenType.TIMESTAMPNTZ: 148>}
ALTER_PARSERS =
{'ADD': <function Parser.<lambda>>, 'AS': <function Parser.<lambda>>, 'ALTER': <function Parser.<lambda>>, 'CLUSTER BY': <function Parser.<lambda>>, 'DELETE': <function Parser.<lambda>>, 'DROP': <function Parser.<lambda>>, 'RENAME': <function Parser.<lambda>>, 'SET': <function Parser.<lambda>>, 'SWAP': <function Parser.<lambda>>, 'MODIFY': <function SnowflakeParser.<lambda>>, 'SESSION': <function SnowflakeParser.<lambda>>, 'UNSET': <function SnowflakeParser.<lambda>>}
STATEMENT_PARSERS =
{<TokenType.ALTER: 218>: <function Parser.<lambda>>, <TokenType.ANALYZE: 438>: <function Parser.<lambda>>, <TokenType.BEGIN: 228>: <function Parser.<lambda>>, <TokenType.CACHE: 231>: <function Parser.<lambda>>, <TokenType.COMMENT: 237>: <function Parser.<lambda>>, <TokenType.COMMIT: 238>: <function Parser.<lambda>>, <TokenType.COPY: 241>: <function Parser.<lambda>>, <TokenType.CREATE: 242>: <function Parser.<lambda>>, <TokenType.DELETE: 256>: <function Parser.<lambda>>, <TokenType.DESC: 257>: <function Parser.<lambda>>, <TokenType.DESCRIBE: 258>: <function Parser.<lambda>>, <TokenType.DROP: 264>: <function Parser.<lambda>>, <TokenType.GRANT: 288>: <function Parser.<lambda>>, <TokenType.REVOKE: 375>: <function Parser.<lambda>>, <TokenType.INSERT: 299>: <function Parser.<lambda>>, <TokenType.KILL: 313>: <function Parser.<lambda>>, <TokenType.LOAD: 320>: <function Parser.<lambda>>, <TokenType.MERGE: 327>: <function Parser.<lambda>>, <TokenType.PIVOT: 354>: <function Parser.<lambda>>, <TokenType.PRAGMA: 359>: <function Parser.<lambda>>, <TokenType.REFRESH: 371>: <function Parser.<lambda>>, <TokenType.ROLLBACK: 380>: <function Parser.<lambda>>, <TokenType.SET: 390>: <function Parser.<lambda>>, <TokenType.TRUNCATE: 409>: <function Parser.<lambda>>, <TokenType.UNCACHE: 412>: <function Parser.<lambda>>, <TokenType.UNPIVOT: 415>: <function Parser.<lambda>>, <TokenType.UPDATE: 416>: <function Parser.<lambda>>, <TokenType.USE: 417>: <function Parser.<lambda>>, <TokenType.SEMICOLON: 19>: <function Parser.<lambda>>, <TokenType.GET: 285>: <function SnowflakeParser.<lambda>>, <TokenType.PUT: 365>: <function SnowflakeParser.<lambda>>, <TokenType.SHOW: 392>: <function SnowflakeParser.<lambda>>}
PROPERTY_PARSERS =
{'ALLOWED_VALUES': <function Parser.<lambda>>, 'ALGORITHM': <function Parser.<lambda>>, 'AUTO': <function Parser.<lambda>>, 'AUTO_INCREMENT': <function Parser.<lambda>>, 'BACKUP': <function Parser.<lambda>>, 'BLOCKCOMPRESSION': <function Parser.<lambda>>, 'CHARSET': <function Parser.<lambda>>, 'CHARACTER SET': <function Parser.<lambda>>, 'CHECKSUM': <function Parser.<lambda>>, 'CLUSTER BY': <function Parser.<lambda>>, 'CLUSTERED': <function Parser.<lambda>>, 'COLLATE': <function Parser.<lambda>>, 'COMMENT': <function Parser.<lambda>>, 'CONTAINS': <function Parser.<lambda>>, 'COPY': <function Parser.<lambda>>, 'DATABLOCKSIZE': <function Parser.<lambda>>, 'DATA_DELETION': <function Parser.<lambda>>, 'DEFINER': <function Parser.<lambda>>, 'DETERMINISTIC': <function Parser.<lambda>>, 'DISTRIBUTED': <function Parser.<lambda>>, 'DUPLICATE': <function Parser.<lambda>>, 'DYNAMIC': <function Parser.<lambda>>, 'DISTKEY': <function Parser.<lambda>>, 'DISTSTYLE': <function Parser.<lambda>>, 'EMPTY': <function Parser.<lambda>>, 'ENGINE': <function Parser.<lambda>>, 'ENVIRONMENT': <function Parser.<lambda>>, 'HANDLER': <function Parser.<lambda>>, 'EXECUTE': <function Parser.<lambda>>, 'EXTERNAL': <function Parser.<lambda>>, 'FALLBACK': <function Parser.<lambda>>, 'FORMAT': <function Parser.<lambda>>, 'FREESPACE': <function Parser.<lambda>>, 'GLOBAL': <function Parser.<lambda>>, 'HEAP': <function Parser.<lambda>>, 'ICEBERG': <function Parser.<lambda>>, 'IMMUTABLE': <function Parser.<lambda>>, 'INHERITS': <function Parser.<lambda>>, 'INPUT': <function Parser.<lambda>>, 'JOURNAL': <function Parser.<lambda>>, 'LANGUAGE': <function Parser.<lambda>>, 'LAYOUT': <function Parser.<lambda>>, 'LIFETIME': <function Parser.<lambda>>, 'LIKE': <function Parser.<lambda>>, 'LOCATION': <function SnowflakeParser.<lambda>>, 'LOCK': <function Parser.<lambda>>, 'LOCKING': <function Parser.<lambda>>, 'LOG': <function Parser.<lambda>>, 'MATERIALIZED': <function Parser.<lambda>>, 'MERGEBLOCKRATIO': <function Parser.<lambda>>, 'MODIFIES': <function Parser.<lambda>>, 'MULTISET': <function Parser.<lambda>>, 'NO': <function Parser.<lambda>>, 'ON': <function Parser.<lambda>>, 'ORDER BY': <function Parser.<lambda>>, 'OUTPUT': <function Parser.<lambda>>, 'PARTITION': <function Parser.<lambda>>, 'PARTITION BY': <function Parser.<lambda>>, 'PARTITIONED BY': <function Parser.<lambda>>, 'PARTITIONED_BY': <function Parser.<lambda>>, 'PRIMARY KEY': <function Parser.<lambda>>, 'RANGE': <function Parser.<lambda>>, 'READS': <function Parser.<lambda>>, 'REMOTE': <function Parser.<lambda>>, 'RETURNS': <function Parser.<lambda>>, 'STRICT': <function Parser.<lambda>>, 'STREAMING': <function Parser.<lambda>>, 'ROW': <function SnowflakeParser.<lambda>>, 'ROW_FORMAT': <function Parser.<lambda>>, 'SAMPLE': <function Parser.<lambda>>, 'SECURE': <function Parser.<lambda>>, 'SECURITY': <function Parser.<lambda>>, 'SQL SECURITY': <function Parser.<lambda>>, 'SET': <function Parser.<lambda>>, 'SETTINGS': <function Parser.<lambda>>, 'SHARING': <function Parser.<lambda>>, 'SORTKEY': <function Parser.<lambda>>, 'SOURCE': <function Parser.<lambda>>, 'STABLE': <function Parser.<lambda>>, 'STORED': <function Parser.<lambda>>, 'SYSTEM_VERSIONING': <function Parser.<lambda>>, 'TBLPROPERTIES': <function Parser.<lambda>>, 'TEMP': <function Parser.<lambda>>, 'TEMPORARY': <function Parser.<lambda>>, 'TO': <function Parser.<lambda>>, 'TRANSIENT': <function Parser.<lambda>>, 'TRANSFORM': <function Parser.<lambda>>, 'TTL': <function Parser.<lambda>>, 'USING': <function SnowflakeParser.<lambda>>, 'UNLOGGED': <function Parser.<lambda>>, 'VOLATILE': <function Parser.<lambda>>, 'WITH': <function Parser.<lambda>>, 'CREDENTIALS': <function SnowflakeParser.<lambda>>, 'FILE_FORMAT': <function SnowflakeParser.<lambda>>, 'TAG': <function SnowflakeParser.<lambda>>}
DESCRIBE_QUALIFIER_PARSERS: ClassVar[dict[str, Callable]] =
{'API': <function SnowflakeParser.<lambda>>, 'APPLICATION': <function SnowflakeParser.<lambda>>, 'CATALOG': <function SnowflakeParser.<lambda>>, 'COMPUTE': <function SnowflakeParser.<lambda>>, 'DATABASE': <function SnowflakeParser.<lambda>>, 'DYNAMIC': <function SnowflakeParser.<lambda>>, 'EXTERNAL': <function SnowflakeParser.<lambda>>, 'HYBRID': <function SnowflakeParser.<lambda>>, 'ICEBERG': <function SnowflakeParser.<lambda>>, 'MASKING': <function SnowflakeParser.<lambda>>, 'MATERIALIZED': <function SnowflakeParser.<lambda>>, 'NETWORK': <function SnowflakeParser.<lambda>>, 'ROW': <function SnowflakeParser.<lambda>>, 'SECURITY': <function SnowflakeParser.<lambda>>}
TYPE_CONVERTERS =
{<DType.DECIMAL: 'DECIMAL'>: <function build_default_decimal_type.<locals>._builder>}
SHOW_PARSERS =
{'DATABASES': <function _show_parser.<locals>._parse>, 'SCHEMAS': <function _show_parser.<locals>._parse>, 'OBJECTS': <function _show_parser.<locals>._parse>, 'TABLES': <function _show_parser.<locals>._parse>, 'VIEWS': <function _show_parser.<locals>._parse>, 'PRIMARY KEYS': <function _show_parser.<locals>._parse>, 'IMPORTED KEYS': <function _show_parser.<locals>._parse>, 'UNIQUE KEYS': <function _show_parser.<locals>._parse>, 'SEQUENCES': <function _show_parser.<locals>._parse>, 'STAGES': <function _show_parser.<locals>._parse>, 'COLUMNS': <function _show_parser.<locals>._parse>, 'USERS': <function _show_parser.<locals>._parse>, 'FILE FORMATS': <function _show_parser.<locals>._parse>, 'FUNCTIONS': <function _show_parser.<locals>._parse>, 'PROCEDURES': <function _show_parser.<locals>._parse>, 'WAREHOUSES': <function _show_parser.<locals>._parse>, 'ICEBERG TABLES': <function _show_parser.<locals>._parse>, 'TERSE ICEBERG TABLES': <function _show_parser.<locals>._parse>, 'TERSE DATABASES': <function _show_parser.<locals>._parse>, 'TERSE SCHEMAS': <function _show_parser.<locals>._parse>, 'TERSE OBJECTS': <function _show_parser.<locals>._parse>, 'TERSE TABLES': <function _show_parser.<locals>._parse>, 'TERSE VIEWS': <function _show_parser.<locals>._parse>, 'TERSE SEQUENCES': <function _show_parser.<locals>._parse>, 'TERSE USERS': <function _show_parser.<locals>._parse>, 'TERSE PRIMARY KEYS': <function _show_parser.<locals>._parse>, 'TERSE IMPORTED KEYS': <function _show_parser.<locals>._parse>, 'TERSE UNIQUE KEYS': <function _show_parser.<locals>._parse>}
SHOW_TRIE =
{'DATABASES': {0: True}, 'SCHEMAS': {0: True}, 'OBJECTS': {0: True}, 'TABLES': {0: True}, 'VIEWS': {0: True}, 'PRIMARY': {'KEYS': {0: True}}, 'IMPORTED': {'KEYS': {0: True}}, 'UNIQUE': {'KEYS': {0: True}}, 'SEQUENCES': {0: True}, 'STAGES': {0: True}, 'COLUMNS': {0: True}, 'USERS': {0: True}, 'FILE': {'FORMATS': {0: True}}, 'FUNCTIONS': {0: True}, 'PROCEDURES': {0: True}, 'WAREHOUSES': {0: True}, 'ICEBERG': {'TABLES': {0: True}}, 'TERSE': {'ICEBERG': {'TABLES': {0: True}}, 'DATABASES': {0: True}, 'SCHEMAS': {0: True}, 'OBJECTS': {0: True}, 'TABLES': {0: True}, 'VIEWS': {0: True}, 'SEQUENCES': {0: True}, 'USERS': {0: True}, 'PRIMARY': {'KEYS': {0: True}}, 'IMPORTED': {'KEYS': {0: True}}, 'UNIQUE': {'KEYS': {0: True}}}}
CONSTRAINT_PARSERS =
{'AUTOINCREMENT': <function Parser.<lambda>>, 'AUTO_INCREMENT': <function Parser.<lambda>>, 'CASESPECIFIC': <function Parser.<lambda>>, 'CHARACTER SET': <function Parser.<lambda>>, 'CHECK': <function Parser.<lambda>>, 'COLLATE': <function Parser.<lambda>>, 'COMMENT': <function Parser.<lambda>>, 'COMPRESS': <function Parser.<lambda>>, 'CLUSTERED': <function Parser.<lambda>>, 'NONCLUSTERED': <function Parser.<lambda>>, 'DEFAULT': <function Parser.<lambda>>, 'ENCODE': <function Parser.<lambda>>, 'EPHEMERAL': <function Parser.<lambda>>, 'EXCLUDE': <function Parser.<lambda>>, 'FOREIGN KEY': <function Parser.<lambda>>, 'FORMAT': <function Parser.<lambda>>, 'GENERATED': <function Parser.<lambda>>, 'IDENTITY': <function Parser.<lambda>>, 'INLINE': <function Parser.<lambda>>, 'LIKE': <function Parser.<lambda>>, 'NOT': <function Parser.<lambda>>, 'NULL': <function Parser.<lambda>>, 'ON': <function Parser.<lambda>>, 'PATH': <function Parser.<lambda>>, 'PERIOD': <function Parser.<lambda>>, 'PRIMARY KEY': <function Parser.<lambda>>, 'REFERENCES': <function Parser.<lambda>>, 'TITLE': <function Parser.<lambda>>, 'TTL': <function Parser.<lambda>>, 'UNIQUE': <function Parser.<lambda>>, 'UPPERCASE': <function Parser.<lambda>>, 'WITH': <function SnowflakeParser.<lambda>>, 'BUCKET': <function Parser.<lambda>>, 'TRUNCATE': <function Parser.<lambda>>, 'MASKING': <function SnowflakeParser.<lambda>>, 'PROJECTION': <function SnowflakeParser.<lambda>>, 'TAG': <function SnowflakeParser.<lambda>>}
CREATABLES =
{<TokenType.RULE: 384>, <TokenType.DICTIONARY: 260>, <TokenType.SEQUENCE: 388>, <TokenType.MODEL: 329>, <TokenType.DATABASE: 79>, <TokenType.COLUMN: 80>, <TokenType.STORAGE_INTEGRATION: 399>, <TokenType.FILE_FORMAT: 274>, <TokenType.SCHEMA: 82>, <TokenType.TABLE: 83>, <TokenType.STAGE: 85>, <TokenType.TAG: 404>, <TokenType.STREAMLIT: 87>, <TokenType.FOREIGN_KEY: 280>, <TokenType.WAREHOUSE: 84>, <TokenType.TRIGGER: 410>, <TokenType.TYPE: 411>, <TokenType.FUNCTION: 284>, <TokenType.PACKAGE: 350>, <TokenType.POLICY: 356>, <TokenType.VIEW: 421>, <TokenType.SEMANTIC_VIEW: 422>, <TokenType.POOL: 357>, <TokenType.INDEX: 296>, <TokenType.VOLUME: 424>, <TokenType.PROCEDURE: 362>, <TokenType.INTEGRATION: 301>, <TokenType.CONSTRAINT: 240>, <TokenType.SINK: 436>, <TokenType.SOURCE: 437>, <TokenType.NAMESPACE: 439>, <TokenType.ROLE: 379>}
LAMBDAS =
{<TokenType.ARROW: 45>: <function SnowflakeParser.<lambda>>, <TokenType.FARROW: 47>: <function Parser.<lambda>>}
COLUMN_OPERATORS =
{<TokenType.DOT: 8>: None, <TokenType.DOTCOLON: 12>: <function Parser.<lambda>>, <TokenType.DCOLON: 14>: <function Parser.<lambda>>, <TokenType.ARROW: 45>: <function Parser.<lambda>>, <TokenType.DARROW: 46>: <function Parser.<lambda>>, <TokenType.HASH_ARROW: 49>: <function Parser.<lambda>>, <TokenType.DHASH_ARROW: 50>: <function Parser.<lambda>>, <TokenType.PLACEHOLDER: 355>: <function Parser.<lambda>>, <TokenType.EXCLAMATION: 70>: <function SnowflakeParser.<lambda>>}
1310 def build_cast(self, strict: bool, **kwargs) -> exp.Expr: 1311 to = kwargs.get("to") 1312 if not strict and to and to.this == exp.DataType.Type.BOOLEAN: 1313 return self.expression(exp.ToBoolean(this=kwargs.get("this"), safe=True)) 1314 cast = super().build_cast(strict, **kwargs) 1315 if isinstance(cast, exp.TryCast) and to: 1316 if to.this in exp.DataType.TEXT_TYPES and to.expressions: 1317 cast.set("null_on_text_overflow", True) 1318 elif to.this == exp.DType.DATE and cast.this.is_string: 1319 cast.set("probe_date_format", True) 1320 return cast
Inherited Members
- sqlglot.parser.Parser
- Parser
- ENUM_TYPE_TOKENS
- AGGREGATE_TYPE_TOKENS
- SIGNED_TO_UNSIGNED_TYPE_TOKEN
- SUBQUERY_PREDICATES
- SUBQUERY_TOKENS
- RESERVED_TOKENS
- DB_CREATABLES
- TRIGGER_EVENTS
- ALTERABLES
- ARRAY_CONSTRUCTORS
- COMMENT_TABLE_ALIAS_TOKENS
- UPDATE_ALIAS_TOKENS
- TRIM_TYPES
- IDENTIFIER_TOKENS
- BRACKETS
- COLUMN_POSTFIX_TOKENS
- TABLE_POSTFIX_TOKENS
- FUNC_TOKENS
- CONJUNCTION
- ASSIGNMENT
- DISJUNCTION
- EQUALITY
- COMPARISON
- BITWISE
- TERM
- FACTOR
- EXPONENT
- TIMES
- SET_OPERATIONS
- JOIN_METHODS
- JOIN_SIDES
- JOIN_KINDS
- JOIN_HINTS
- TABLE_TERMINATORS
- LAMBDA_ARG_TERMINATORS
- CAST_COLUMN_OPERATORS
- EXPRESSION_PARSERS
- UNARY_PARSERS
- STRING_PARSERS
- NUMERIC_PARSERS
- PRIMARY_PARSERS
- PLACEHOLDER_PARSERS
- PIPE_SYNTAX_TRANSFORM_PARSERS
- ALTER_ALTER_PARSERS
- SCHEMA_UNNAMED_CONSTRAINTS
- NO_PAREN_FUNCTION_PARSERS
- INVALID_FUNC_NAME_TOKENS
- FUNCTIONS_WITH_ALIASED_ARGS
- KEY_VALUE_DEFINITIONS
- QUERY_MODIFIER_PARSERS
- QUERY_MODIFIER_TOKENS
- SET_PARSERS
- TYPE_LITERAL_PARSERS
- DDL_SELECT_TOKENS
- PRE_VOLATILE_TOKENS
- TRANSACTION_KIND
- TRANSACTION_CHARACTERISTICS
- CONFLICT_ACTIONS
- TRIGGER_TIMING
- TRIGGER_DEFERRABLE
- CREATE_SEQUENCE
- ISOLATED_LOADING_OPTIONS
- USABLES
- CAST_ACTIONS
- SCHEMA_BINDING_OPTIONS
- PROCEDURE_OPTIONS
- EXECUTE_AS_OPTIONS
- KEY_CONSTRAINT_OPTIONS
- WINDOW_EXCLUDE_OPTIONS
- INSERT_ALTERNATIVES
- CLONE_KEYWORDS
- HISTORICAL_DATA_PREFIX
- HISTORICAL_DATA_KIND
- OPCLASS_FOLLOW_KEYWORDS
- OPTYPE_FOLLOW_TOKENS
- TABLE_INDEX_HINT_TOKENS
- VIEW_ATTRIBUTES
- WINDOW_ALIAS_TOKENS
- WINDOW_BEFORE_PAREN_TOKENS
- WINDOW_SIDES
- JSON_KEY_VALUE_SEPARATOR_TOKENS
- FETCH_TOKENS
- ADD_CONSTRAINT_TOKENS
- DISTINCT_TOKENS
- UNNEST_OFFSET_ALIAS_TOKENS
- SELECT_START_TOKENS
- COPY_INTO_VARLEN_OPTIONS
- IS_JSON_PREDICATE_KIND
- ODBC_DATETIME_LITERALS
- ON_CONDITION_TOKENS
- PRIVILEGE_FOLLOW_TOKENS
- DESCRIBE_STYLES
- SET_ASSIGNMENT_DELIMITERS
- ANALYZE_STYLES
- ANALYZE_EXPRESSION_PARSERS
- PARTITION_KEYWORDS
- AMBIGUOUS_ALIAS_TOKENS
- OPERATION_MODIFIERS
- RECURSIVE_CTE_SEARCH_KIND
- SECURITY_PROPERTY_KEYWORDS
- MODIFIABLES
- STRICT_CAST
- PREFIXED_PIVOT_COLUMNS
- PIVOT_COLUMN_NAMING
- LOG_DEFAULTS_TO_LN
- TABLESAMPLE_CSV
- SET_REQUIRES_ASSIGNMENT_DELIMITER
- TRIM_PATTERN_FIRST
- STRING_ALIASES
- MODIFIERS_ATTACHED_TO_SET_OP
- SET_OP_MODIFIERS
- NO_PAREN_IF_COMMANDS
- JSON_ARROWS_REQUIRE_JSON_TYPE
- VALUES_FOLLOWED_BY_PAREN
- SUPPORTS_IMPLICIT_UNNEST
- INTERVAL_SPANS
- SUPPORTS_PARTITION_SELECTION
- WRAPPED_TRANSFORM_COLUMN_CONSTRAINT
- OPTIONAL_ALIAS_TOKEN_CTE
- ALTER_RENAME_REQUIRES_COLUMN
- ALTER_TABLE_PARTITIONS
- JOINS_HAVE_EQUAL_PRECEDENCE
- ZONE_AWARE_TIMESTAMP_CONSTRUCTOR
- MAP_KEYS_ARE_ARBITRARY_EXPRESSIONS
- ADD_JOIN_ON_TRUE
- SUPPORTS_OMITTED_INTERVAL_SPAN_UNIT
- SET_TRIE
- error_level
- error_message_context
- max_errors
- max_nodes
- dialect
- sql
- errors
- reset
- raise_error
- validate_expression
- parse
- parse_into
- check_errors
- expression
- parse_set_operation
RANKING_WINDOW_FUNCTIONS_WITH_FRAME =
(<class 'sqlglot.expressions.aggregate.FirstValue'>, <class 'sqlglot.expressions.aggregate.LastValue'>, <class 'sqlglot.expressions.aggregate.NthValue'>)
def
build_object_construct( args: list) -> sqlglot.expressions.array.StarMap | sqlglot.expressions.array.Struct:
1356def build_object_construct(args: list) -> exp.StarMap | exp.Struct: 1357 expression = parser.build_var_map(args) 1358 1359 if isinstance(expression, exp.StarMap): 1360 return expression 1361 1362 return exp.Struct( 1363 expressions=[ 1364 exp.PropertyEQ(this=k, expression=v) for k, v in zip(expression.keys, expression.values) 1365 ] 1366 )