Skip to content

Commit

Permalink
Fix(tsql): add support for 'culture' argument in FORMAT (#2047)
Browse files Browse the repository at this point in the history
  • Loading branch information
georgesittas authored Aug 14, 2023
1 parent 0746b6f commit a35cfe0
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 12 deletions.
21 changes: 11 additions & 10 deletions sqlglot/dialects/tsql.py
Original file line number Diff line number Diff line change
Expand Up @@ -79,22 +79,23 @@ def _format_time(args: t.List) -> E:


def _parse_format(args: t.List) -> exp.Expression:
assert len(args) == 2
this = seq_get(args, 0)
fmt = seq_get(args, 1)
culture = seq_get(args, 2)

fmt = args[1]
number_fmt = fmt.name in TRANSPILE_SAFE_NUMBER_FMT or not DATE_FMT_RE.search(fmt.name)
number_fmt = fmt and (fmt.name in TRANSPILE_SAFE_NUMBER_FMT or not DATE_FMT_RE.search(fmt.name))

if number_fmt:
return exp.NumberToStr(this=args[0], format=fmt)
return exp.NumberToStr(this=this, format=fmt, culture=culture)

return exp.TimeToStr(
this=args[0],
format=exp.Literal.string(
if fmt:
fmt = exp.Literal.string(
format_time(fmt.name, TSQL.FORMAT_TIME_MAPPING)
if len(fmt.name) == 1
else format_time(fmt.name, TSQL.TIME_MAPPING)
),
)
)

return exp.TimeToStr(this=this, format=fmt, culture=culture)


def _parse_eomonth(args: t.List) -> exp.Expression:
Expand Down Expand Up @@ -147,7 +148,7 @@ def _format_sql(self: generator.Generator, expression: exp.NumberToStr | exp.Tim
)
)
)
return self.func("FORMAT", expression.this, fmt)
return self.func("FORMAT", expression.this, fmt, expression.args.get("culture"))


def _string_agg_sql(self: generator.Generator, expression: exp.GroupConcat) -> str:
Expand Down
4 changes: 2 additions & 2 deletions sqlglot/expressions.py
Original file line number Diff line number Diff line change
Expand Up @@ -4649,7 +4649,7 @@ class StrToUnix(Func):


class NumberToStr(Func):
arg_types = {"this": True, "format": True}
arg_types = {"this": True, "format": True, "culture": False}


class FromBase(Func):
Expand Down Expand Up @@ -4686,7 +4686,7 @@ class StddevSamp(AggFunc):


class TimeToStr(Func):
arg_types = {"this": True, "format": True}
arg_types = {"this": True, "format": True, "culture": False}


class TimeToTimeStr(Func):
Expand Down
3 changes: 3 additions & 0 deletions tests/dialects/test_tsql.py
Original file line number Diff line number Diff line change
Expand Up @@ -971,9 +971,12 @@ def test_top(self):
)

def test_format(self):
self.validate_identity("SELECT FORMAT(foo, 'dddd', 'de-CH')")
self.validate_identity("SELECT FORMAT(EndOfDayRate, 'N', 'en-us')")
self.validate_identity("SELECT FORMAT('01-01-1991', 'd.mm.yyyy')")
self.validate_identity("SELECT FORMAT(12345, '###.###.###')")
self.validate_identity("SELECT FORMAT(1234567, 'f')")

self.validate_all(
"SELECT FORMAT(1000000.01,'###,###.###')",
write={"spark": "SELECT FORMAT_NUMBER(1000000.01, '###,###.###')"},
Expand Down

0 comments on commit a35cfe0

Please sign in to comment.