This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2020-06-21
Channels
- # announcements (3)
- # aws (11)
- # babashka (5)
- # beginners (116)
- # cider (30)
- # clara (1)
- # clj-kondo (15)
- # clojure (17)
- # clojure-dev (9)
- # clojure-europe (2)
- # clojure-italy (1)
- # clojure-uk (3)
- # clojurescript (9)
- # conjure (3)
- # duct (22)
- # exercism (1)
- # fulcro (8)
- # graalvm (5)
- # graphql (3)
- # helix (3)
- # joker (3)
- # kaocha (2)
- # off-topic (9)
- # pathom (4)
- # re-frame (1)
- # rum (6)
- # shadow-cljs (81)
- # sql (6)
- # xtdb (9)
The general solution to n+1 in GraphQL is to use a data loader; we have an internal one that we hope to release as open source in the future, and there's also Superlifter: https://github.com/oliyh/superlifter
I think I've so far only hit n+1 once in our graphql usage, and what I did was have the parent object resolver build a cache, and add the cache to the context, and then the field resolver checks for values in the cache. So if the field is being resolved on its own, no cache and it goes to the database, if the field is being resolved as part of a collection under the parent, it will find itself in the cache the parent built.