我有一个像这样的Datascript数据库:
{:block/id {:db/unique :db.unique/identity}
:block/children {:db/cardinality :db.cardinality/many}
}
[:block/children
包含其他块的:block/id
我一直在尝试编写查询以查找哪个块具有另一个块作为其子代。
这是我尝试过的示例:
(ds/q '[:find ?parent-ds-id
:where
[1100 :block/id ?block-id]
[?parent-ds-id :block/children ?block-id]]
@conn)
我只是把空集换回来。我应该如何打扮?block-id
,以便获得以?block-id
作为其子级之一的块的实体ID? (每个块只有一个父母)
此问题可能与您使用的数据有关。这是个您所追求的工作示例:
(let [schema {:block/id {:db/unique :db.unique/identity}
:block/children {:db/valueType :db.type/ref
:db/cardinality :db.cardinality/many}}
conn (d/create-conn schema)
idify (fn [id] (* 100 id)) ; just fake some id
block (fn [id] {:db/id (idify id) :block/id id})
rel (fn [parent-id child-id] {:db/id (idify parent-id) :block/children (idify child-id)})]
(d/transact! conn [(block 1)
(block 2)
(block 3)
(rel 1 2)
(rel 1 3)])
(d/q
'[:find ?parent-id
:in $ ?child-id
:where
[?child :block/id ?child-id]
[?parent :block/children ?child]
[?parent :block/id ?parent-id]]
@conn
2))
; → #{[1]}
尽管您的区块ID很可能已经是您想要的唯一ID用于您的实体,它使用不同的实体ID清楚地说明如何合并数据。
此查询建立: