0

我正在使用 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 会根据记录的数量返回不同的类型(这将帮助我更好地理解这一点),其次 - 我应该怎么做?

4

1 回答 1

2

看来你错过了一个函数调用。尝试这个:

(cheshire.core/generate-string (x))
于 2014-04-05T15:50:44.090 回答