最明显的方法是从Clojure Contrib加载JDBC支持,并编写一些函数将map/struct转换为表。这样做的一个缺点是它不是非常灵活;对结构的更改将需要对DDL进行更改。这意味着要么编写DDL生成(困难),要么手工编写迁移(无聊)。
有哪些替代方案?答案必须是酸的,排除序列化到文件,等等。
发布于 2009-06-16 12:28:11
使用CouchDB的Java客户端库和clojure.contrib.json.read/write对我来说工作得相当好。但是,CouchDB的一致性保证可能不足以满足您的需要。
发布于 2011-01-11 22:05:26
FleetDB是一个用Clojure实现的数据库。它有一个非常自然的使用map/struct的语法,例如插入:
(client ["insert" "accounts" {"id" 1, "owner" "Eve", "credits" 100}])然后选择
(client ["select" "accounts" {"where" ["=" "id" 1]}])http://fleetdb.org/
发布于 2009-06-16 16:45:18
在仍然使用关系数据库的Clojure中持久存储地图的一种选择是将地图数据存储在一个不透明的blob中。如果需要搜索记录,可以将索引存储在不同的表中。例如,您可以阅读FriendFeed是如何在MySQL - http://bret.appspot.com/entry/how-friendfeed-uses-mysql之上存储无模式数据的
另一种选择是使用实体-属性-值模型(EAV)在数据库中存储数据。你可以在维基百科上阅读更多关于EAV的信息(我想发布一个链接,但我是一个新用户,只能发布一个链接)。
另一种选择是使用BerkeleyDB for Java -这是一种原生Java解决方案,提供了ACID和记录级锁定。(发布链接也有同样的问题)。
https://stackoverflow.com/questions/995331
复制相似问题