Remix.run Logo
lovasoa 8 hours ago

The thing I would have liked to know is why they don't use an existing fast SQL parser. Was being slightly incompatible with all existing SQL dialects a product requirement?

robbie-c 8 hours ago | parent | next [-]

Our SQL is very similar to ClickHouse SQL, in that we used ClickHouse SQL as a starting point as that's what our underlying DB is. We needed to have our own parser so that we could add additional language features on top.

bonzini 6 hours ago | parent [-]

I think you should clarify that (or whether) while you didn't look at the generated code, you are actually going to adjust it in the future.

How did the two approaches compare in terms of code readability?

nijave an hour ago | parent | prev | next [-]

Yeah curious why they didn't use Presto/Trino, DuckDB, or Clickhouse SQL directly with UDFs and views to augment

Zuora exposes a Trino-based data warehouse which is quite nice and powerful

Besides the parser side, existing dev tools and docs automatically work, too

__s 6 hours ago | parent | prev | next [-]

This is pretty much the case with every SQL dialect

-warren 7 hours ago | parent | prev [-]

I think thats exactly what indirectly happened. This guy didnt optimize the parser. Someone else did -- years ago. That work was pulled into the LLM and made it look like magic.

bonzini 6 hours ago | parent [-]

Note that it's not a particularly optimized algorithm: recursive descent + specialized subparser for expressions is simply the standard way to write parsers by hand. It's ANTLR which is super flexible but also dog slow.

robbie-c 5 hours ago | parent [-]

Yeah, one of the interesting parts to me while working on this is that the breakpoint for when it's worth writing your own parser vs accepting ANTLR's slowness has shifted massively. Previously it would have been someone's full-time job to maintain. Now with this approach you can get the best of both worlds.