This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2022-03-26
Channels
- # announcements (6)
- # babashka (29)
- # babashka-sci-dev (2)
- # beginners (129)
- # calva (9)
- # clara (16)
- # cljdoc (49)
- # clojure (125)
- # clojure-bay-area (3)
- # clojure-europe (55)
- # clojure-france (1)
- # clojuredesign-podcast (8)
- # clojurescript (85)
- # conjure (3)
- # core-logic (2)
- # cursive (1)
- # events (1)
- # honeysql (61)
- # jobs-discuss (23)
- # lsp (69)
- # malli (14)
- # nrepl (3)
- # off-topic (16)
- # portal (11)
- # re-frame (8)
- # releases (1)
- # ring (2)
- # shadow-cljs (12)
- # vim (42)
- # xtdb (18)
To @denis.baudinot’s point, I've found that the core structure of a project can be surprisingly hard to find an identify. I recently read through the procps-ng
codebase so I could put some similar functions in something I was writing, and it took me way too long to figure out that one of the key sections of it was setting up and then calling a function pointer. It was one tiny easy to miss line that was keeping me from understanding what was going on at first glance.
"Monaco at Monza speeds + Spa-style flat out sweeping corners" is a dangerous combination for sure.
Yeah it leaves me a little confused. Grade 1 certification for tracks means really expensive modifications or just slap some concrete walls along the whole thing?
I've read the criticism of the SQL and ... well... What should I do if I have my personal project with PostgreSQL but at work I have XTDB and there I have a collection document attribute (similar to psql array)... but the difference is that I can look up the document by the value in that collection. I know that I could make something similar in Postgresql if I'd use a table for this... but it's so bad... I'm frustrated. Because not only I'll need a table for this. But then it will also make the join. And every query that I'll have will need to be a join... oh noo
So after a while when I didn't look at that code at all... All of this untested sql code... it's still code but I can't have tests for it... oh no.
What prevents you from using XTDB for your personal project as well? :) Also, you can look up rows by values within an array. But I don't quite recall whether any kind of index could be used for that.
Psql array = full scan https://www.postgresql.org/docs/current/arrays.html And the docs say that it's a bad practice. And my project... well it's quite big and I can't reuse what I already have because well... I have psql queries... so I'm in a bad spot.
> Psql array = full scan
Not sure that's correct: https://stackoverflow.com/a/29245753/564509
> it's quite big and I can't reuse what I already have because well... I have psql queries
You can always migrate? Surely you have something like migratus
or whatever to help you with that. You can unroll arrays if you want, and then hide all those joins behind a view. You can even create a view that rolls those values back into arrays to make migrations gradual.
In my opinion it is easy to create a usable layer over SQL for querying, but the crappy SQL data modification syntax is hard to abstract away, at least when things need to happen in multiple tables.
I was designing a layer for this but didn't do any coding yet. But yes, I don't even know what would be the way to wrap multi-table writes... I don't think it's a good idea... it's probably too hard. Transactions... idk...
If I absolutely had to try, I might try going with something like this as the API:
[{"type": "insert",
"table": "Person"
"values": {"email": ""},
"as": "newUser"},
{"type": "insert",
"table": "Project"
"values": {"title": "New Project", "manager_id": ["var", "newUser.id"]}}]
I don't know if it's relevant but well... https://github.com/seancorfield/honeysql