ITPub博客

首页 > 应用开发 > IT综合 > 一句话得到中间值的多条记录

一句话得到中间值的多条记录

IT综合 作者:rqgxy 时间:2020-05-22 14:25:49 0 删除 编辑

这个计算步骤比较多,首先需要用 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 脚本》

具体使用方法可参考  《如何使用集算器》


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31555597/viewspace-2693745/,如需转载,请注明出处,否则将追究法律责任。

全部评论

注册时间:2018-09-20

  • 博文量
    232
  • 访问量
    117950