This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2018-05-14
Channels
- # architecture (5)
- # beginners (36)
- # boot (3)
- # cider (89)
- # clara (35)
- # cljsrn (6)
- # clojure (123)
- # clojure-dev (15)
- # clojure-italy (9)
- # clojure-nl (14)
- # clojure-spec (11)
- # clojure-uk (192)
- # clojurescript (27)
- # cursive (22)
- # data-science (1)
- # datascript (1)
- # datomic (31)
- # defnpodcast (1)
- # duct (1)
- # emacs (9)
- # fulcro (2)
- # graphql (16)
- # jobs-discuss (10)
- # juxt (1)
- # keechma (7)
- # mount (4)
- # off-topic (83)
- # onyx (8)
- # pedestal (5)
- # portkey (1)
- # re-frame (44)
- # reagent (29)
- # reitit (4)
- # remote-jobs (1)
- # ring-swagger (1)
- # rum (24)
- # shadow-cljs (1)
- # spacemacs (30)
- # tools-deps (6)
- # vim (23)
@eslachance datascript is not organized around tables, but around attributes. There’s single “entities” space which stores ids, and any entity can have any attributes attached. If you need different “tables”, that would be namespaced attributes. E.g. one entity would have :guild/name and :guild/score attached, anothrer one would have :user/name and :user/email. That would create two entities of different “kind”, purely because of the types of attributes attached. There’s also a possiblity to “mix” entities or have shared attributes (e.g. everyone can have :name with no regard to entity type). I understand this sounds unconventional, but it’s actually quite a nice model to work with. It’s even more powerful in couple of ways that traditional tables