Как написать запрос для получения результата ключа с количеством элементов / многие из них будут картой, а не вектором в datascript

Предположим, что datascript db имеет схему:

(def schema {:maker/cars {:db/cardinality :db.cardinality/many
                          :db/valueType :db.type/ref}})
(def conn (d/create-conn schema)

И вставил несколько объектов:

{:db/id 1
 :car/name "x"}
{:db/id 2
 :car/name "y"}
{:db/id 3
 :car/name "z"}
{:db/id 4 
 :maker/name "Honda"
 :maker/cars [1 2 3]}

Тогда запрос

(d/q '[:find [(pull ?e [:maker/name  {:maker/cars [:car/name]}])]
                 :where [?e :maker/name "Honda"]] @conn)

получим результат:

[#:maker{:name "Honda",
     :cars [#:car{:name "x"} #:car{:name "y"} #:car{:name "z"}]}]

:maker/cars это вектор.

Как написать запрос, чтобы получить результат, как показано ниже?

[#:maker{:name "Honda",
     :cars {1 #:car{:name "x"}
            2 #:car{:name "y"}
            3 #:car{:name "z"}}]

Пробовал, но не повезло...

1 ответ

Решение

Нет выбора. Существует не так много вариантов управления формой данных, которые возвращает API Pull. Просто выполните свою собственную постобработку для результата, который возвращает DataScript

Другие вопросы по тегам