我正在使用 SQL Korma 在数据库上运行一些简单的示例,并尝试使用 Cheshire 将其转换为 JSON。
当我只返回 1 条记录但当我有超过 1 个结果时抛出错误时,这很有效。
这是2个功能:
(defn get-room [id]
(first (select room
(where {:id id})
(limit 1))))
(defn get-rooms []
(select room))
和数据:
(def x get-rooms)
(def y (get-room 1))
X 的类型为 testproj.models.db:
(x)
=> [{:created_on "2014-04-05 13:19:47", :id 1, :description "Room 1"} {:created_on "2014-04-05 13:20:17", :id 2, :description "Room 2"} {:created_on "2014-04-05 13:20:20", :id 3, :description "Room 3"}]
因为 y 是一个 Hashmap:
(pr-str y)
=> "{:created_on \"2014-04-05 13:19:47\", :id 1, :description \"Room 1\"}"
尝试转换为 Json:
(cheshire.core/generate-string x)
JsonGenerationException Cannot JSON encode object of class: class testproj.models.db$get_rooms: testproj.models.db$get_rooms@507501ff cheshire.generate/generate (generate.clj:147)
(cheshire.core/generate-string y)
=> "{\"created_on\":\"2014-04-05 13:19:47\",\"id\":1,\"description\":\"Room 1\"}"
为什么 korma 会根据记录的数量返回不同的类型(这将帮助我更好地理解这一点),其次 - 我应该怎么做?