this post was submitted on 04 Oct 2023
77 points (86.7% liked)
Programming
17326 readers
217 users here now
Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!
Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.
Hope you enjoy the instance!
Rules
Rules
- Follow the programming.dev instance rules
- Keep content related to programming in some way
- If you're posting long videos try to add in some form of tldr for those who don't want to watch videos
Wormhole
Follow the wormhole through a path of communities [email protected]
founded 1 year ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
I'd recommend everyone check out https://prql-lang.org/. It's SQL, but readable and writable in a sane way.
And no, SQL is NOT readable or writable for anything involving more than a single join.
I'm pretty excited about PRQL. If anything has a shot at replacing SQL, it's something like this (taken from their FAQ):
There's a long road ahead of it to get serious about replacing SQL. Many places won't touch it until there's an ANSI standard and all that. But something built with those goals in mind actually might just do it.
I'm not too much of a fan of the SQL equivalent of SELECT not being at the top. Granted I'm fairly sure there are some arguments for it. Since select is optional there's a higher mental load trying to figure out where and what is actually being returned imo. At least from looking at this for the first time.
On the other hand, i'd kill for f-strings, the top N in group (which is nigh unreadable in SQL), and null handling that doesn't require me to write either COALSECE or NVL too often. The joins were a little less pretty though, I'm quite fond of normal SQL joins since they are very reasonable unless chained beyond the line count your screen can show.
You can write selects with many joins, as long they are regular and either add a column or reduce the result set. You have to write the joins explicitly though. Just shoving all of the restrictions into the where clause will definitely confuse everybody.
The main advantage being more concise syntax?