我正在尝试将 SQL 查询的最大和最小结果提取到 Clojure 中,以便我可以对它们进行数学分析,但我不确定为什么会出现错误。
我在代码中使用了 max 和 min 函数来尝试确定这些结果,尽管我不断收到两个错误,这些错误似乎与我使用:counter关键字的方式有关。
SQL 查询在映射中返回的数据如下所示:
{:date1 "20131007", :data "object1", :counter 1000}
{:date1 "20131007", :data "object2", :counter 50}
{:date1 "20131007", :data "object3", :counter 230}
当我使用此代码时:
minvalue(min(map(keyword :counter)data2))
maxvalue(max(map(keyword :counter)data2))
valrange(- maxvalue minvalue)
valpc(* (/ valrange 100) 10)
x(- maxvalue valpc)
我显然希望将minvalue设置为 50 并将maxvalue设置为 1000 尽管我收到此错误:
java.lang.ClassCastException: clojure.lang.LazySeq cannot be cast to java.lang.Number
如果我从代码中删除 map 函数并再次运行它,我会收到以下错误:
java.lang.ClassCastException: clojure.lang.Keyword cannot be cast to java.lang.Number
由于我完全被卡住了(而且我是 Clojure 的新手,这可能很明显),因此对此任何帮助表示赞赏!谢谢