一句话得到中间值的多条记录
关键字:中间值 重复 多条记录
这个计算步骤比较多,首先需要用 distinct 去重得到值的集合,还要根据它的个数算出中间位置在哪,得到中间位置的值,再查询所有等于中间值的记录。SQL 里比较难保持这些中间状态的变量,得用多层嵌套的子查询实现,写出来有难度,之后了再读懂也不容易。
这种情况如果用集算器 SPL 语言就比较容易,从数据库得到原始数据:
>T=connect(”mysqlDB”).query(“select * from T”)
然后很短的一句话就能把多个计算步骤都囊括了:
>s=T.id(f),m=s.sort().m((s.len()+1)\2),r=T.select(f==m)
除了中间值,还有最大值 / 最小值的相关运算,SPL 进一步提供了 TopN 的几种变种运算,在清晰的分步计算能力之外,又提供了便利,可以取 TopN 的值 / 记录 / 记录在集合中的位置,可以应用到分组子集,参考《TopN 及变种》
当数据不在数据库里时,SPL 加载数据仍然方便:
=file(“d:/t.csv”).import(;,",")
SPL能很方便地嵌入到JAVA应用,可参考《Java 如何调用 SPL 脚本》。
具体使用方法可参考 《如何使用集算器》。