使用 Datomic,我想考虑如何在列表中嵌套列表?

一个示例 Clojure 数据结构将是一些东西(见图 1)。我知道 Datomic 有引用的概念(例如在图 2 中)。但那些只是看起来像标量类型,而不是对象(本身)。

  [{:id 0,
    :symbol DDD,
    :company 3D Systems Corporation,
    :price-difference 1.3100000000000023,
    :event-list [{high 35.11,
                  tickerId 0,
                  WAP 34.491,
                  open 35.07,
                  date 20130426,
                  count 3403,
                  low 33.8,
                  hasGaps false,
                  close 34.53,
                  field historicalData,
                  volume 8667,
                  type historicalData}]}]

图 1
 {:db/id #db/id[:db.part/db]
  :db/ident :district/region
  :db/valueType :db.type/ref
  :db/cardinality :db.cardinality/one
  :db/doc "A district region enum value"
  :db.install/_attribute :db.part/db}

 ;; district/region enum values
 [:db/add #db/id[:db.part/user] :db/ident :region/n]
 [:db/add #db/id[:db.part/user] :db/ident :region/ne]
 [:db/add #db/id[:db.part/user] :db/ident :region/e]
 [:db/add #db/id[:db.part/user] :db/ident :region/se]
 [:db/add #db/id[:db.part/user] :db/ident :region/s]
 [:db/add #db/id[:db.part/user] :db/ident :region/sw]
 [:db/add #db/id[:db.part/user] :db/ident :region/w]
 [:db/add #db/id[:db.part/user] :db/ident :region/nw]

图 2

[编辑]

实际上,我想我可能已经找到了答案 here 。我正在浏览 Day-Of-Datomic 代码库,并找到了下面的示例。但我仍然不清楚是什么将 :comments 命名空间与 :comment/body (或 :comment/author )命名空间明确联系起来。 Datomic 是否只是使用约定将 :comments 链接到 :comment
  ;; comments
  [{:db/id #db/id[:db.part/db]
  :db/ident :comments
    :db/valueType :db.type/ref
    :db/cardinality :db.cardinality/many
    :db/isComponent true
    :db.install/_attribute :db.part/db}
   {:db/id #db/id[:db.part/db]
    :db/ident :comment/body
    :db/valueType :db.type/string
    :db/cardinality :db.cardinality/one
    :db.install/_attribute :db.part/db}
   {:db/id #db/id[:db.part/db]
    :db/ident :comment/author
    :db/valueType :db.type/ref
    :db/cardinality :db.cardinality/one
    :db.install/_attribute :db.part/db}]

图 1

最佳答案

您不能直接保留多维列表/向量,但您可以使用链接实体来完成类似的操作:

;; sample attributes
[{:db/id #db/id[:db.part/db]
  :db/ident :some/ref-value
  :db/valueType :db.type/ref
  :db/isComponent true
  :db/cardinality :db.cardinality/many
  :db.install/_attribute :db.part/db}
  {:db/id #db/id[:db.part/db]
  :db/ident :some/list-value
  :db/valueType :db.type/string
  :db/cardinality :db.cardinality/many
  :db.install/_attribute :db.part/db}]

;; [["a" "b" "c"]["d" "e" "f"]]
 [{:db/id #db/id[:db.part/user -1]
 :some/list-value ["a" "b" "c"]}
 {:db/id #db/id[:db.part/user -2]
 :some/list-value ["d" "e" "f"]}
 {:db/id #db/id[:db.part/user]
 :some/ref-value [#db/id[:db.part/user -1] #db/id[:db.part/user -2]]}]

请注意,您可以使用负数将实体链接在一起。当您处理它们时,它们将被真实的实体 ID 替换。

编辑 :从 0.8.4020 版本开始,Datomic 支持嵌套的 component entities(由 :db/isComponent 指定的包含关系)作为交易数据的一部分。例如
 ;; [["a" "b" "c"]["d" "e" "f"]]
 [{:db/id #db/id[:db.part/db]
   :some/ref-value [{:some/list-value ["a" "b" "c"]}
                    {:some/list-value ["d" "e" "f"]}]}]

嵌套映射扩展为两个子实体,它们都在与容器/父实体相同的分区中创建。有关完整的代码示例,请参阅 https://gist.github.com/a2ndrade/5820364

关于database - 使用 Datomic 嵌套结构,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/16242750/

10-12 05:37