1

我有一个像这样的 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?(每个块只有一个父块)

4

1 回答 1

0

此问题可能与您使用的数据有关。这是您所追求的工作示例:

(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 只是为了清楚地说明如何组合数据。

此查询确定:

  • 我们想要给定块 id 的子实体(通过参数 2)
  • 我们想要引用子实体的父实体
  • 我们想要父实体的块 id
于 2020-06-05T06:45:37.570 回答