fix(pinot): SUBSTR function (#35427)

This commit is contained in:
Beto Dealmeida
2025-10-02 10:29:18 -04:00
committed by GitHub
parent f3349388d0
commit 30021f8ede
2 changed files with 28 additions and 0 deletions

View File

@@ -108,6 +108,12 @@ class Pinot(MySQL):
e.args.get("expression"),
e.this,
),
exp.Substring: lambda self, e: self.func(
"SUBSTR",
e.this,
e.args.get("start"),
e.args.get("length"),
),
}
# Remove DATE_TRUNC transformation - Pinot supports standard SQL DATE_TRUNC
TRANSFORMS.pop(exp.DateTrunc, None)

View File

@@ -590,3 +590,25 @@ def test_pinot_date_sub_unit_quoted() -> None:
# The unit should be quoted: 'DAY' not DAY
assert "DATE_SUB('DAY', -180, NOW())" in result
assert "DATE_SUB(DAY," not in result
def test_substr_cross_dialect_generation() -> None:
"""
Test that SUBSTR is preserved when generating Pinot SQL.
Note that the MySQL dialect (in which Pinot is based) uses SUBSTRING instead of
SUBSTR.
"""
# Parse with Pinot dialect
pinot_sql = "SELECT SUBSTR('hello', 0, 3) FROM users"
parsed = sqlglot.parse_one(pinot_sql, Pinot)
# Generate back to Pinot → should preserve SUBSTR
pinot_output = parsed.sql(dialect=Pinot)
assert "SUBSTR(" in pinot_output
assert "SUBSTRING(" not in pinot_output
# Generate to MySQL → should convert to SUBSTRING
mysql_output = parsed.sql(dialect="mysql")
assert "SUBSTRING(" in mysql_output
assert pinot_output != mysql_output # They should be different