database - 使用 Datomic 嵌套结构

标签 database database-design clojure datomic

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

一个示例 Clojure 数据结构将是某种东西(参见图 1)。我知道 Datomic 有引用的概念(例如 fig.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 命名空间明确绑定(bind)到 :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"]}]}]

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

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

相关文章:

c# - VS2010项目无法添加本地SQL数据库?

mysql - 规范化数据库列

vector - 在 clojure 中,通过内核对向量进行卷积的有效方法是什么?

multithreading - 与 Clojure 的线程同步

php - 需要数据库结构建议

sql - 可序列化和可重复读取隔离级别有什么区别?

sql - 这个关系数据库是健全的还是可以改进的?

clojure - 我的数据有复杂的规范 - 如何生成样本?

MYSQL 只显示最早的重复项

.net - 存储很少更改但经常访问的数据,这是解决方案吗?