Edit on GitHub

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'}
class SnowflakeParser(sqlglot.parser.Parser):
 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.
IDENTIFY_PIVOT_STRINGS = True
TYPED_LAMBDA_ARGS = True
DEFAULT_SAMPLING_METHOD = 'BERNOULLI'
COLON_IS_VARIANT_EXTRACT = True
JSON_EXTRACT_REQUIRES_JSON_EXPRESSION = True
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>>}
STAGED_FILE_SINGLE_TOKENS = {<TokenType.DOT: 8>, <TokenType.MOD: 328>, <TokenType.SLASH: 22>}
FLATTEN_COLUMNS = ['SEQ', 'KEY', 'PATH', 'INDEX', 'VALUE', 'THIS']
SCHEMA_KINDS = {'VIEWS', 'OBJECTS', 'SEQUENCES', 'TABLES', 'UNIQUE KEYS', 'IMPORTED KEYS'}
NON_TABLE_CREATABLES = {'STORAGE INTEGRATION', 'WAREHOUSE', 'STREAMLIT', 'TAG'}
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>>}
def build_cast(self, strict: bool, **kwargs) -> sqlglot.expressions.core.Expr:
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
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    )