我有一个要求,我必须执行多个查询并在带有 where 子句的列上执行 group by,group by 列是固定的,并且 where 条件将在具有可变条件的固定列上执行。只有列名和聚合类型会有所不同例如,如果我有表:
k1 k2 val1 val2
1 1 10 30
1 1 20 31
1 2 30 32
2 2 40 33
2 3 50 34
2 4 60 35
2 4 70 36
3 4 80 37
3 5 90 38
3 5 100 39
t:([] k1:1 1 1 2 2 2 2 3 3 3; k2:1 1 2 2 3 4 4 4 5 5; val1:10 20 30 40 50 60 70 80 90 100; val2:31 31 32 33 34 35 36 37 38 39)
我需要执行的查询就像
select avg_val1:avg val1 by k1 from t where k2 in 2 3 4
select sum_val1:sum val1 by k1 from t where k2 in 2 3
select sum_val2:sum val2 by k1 from t where k2 in 2 3 5
select min_val2:min val2 by k1 from t where k2 in 1 2 3 4 5
我想使用功能查询在一次执行中执行这些查询。我试过了,但无法设置正确的条件和语法
res:?[t;();(enlist`k1)!enlist`k1;(`avg_val1;`sum_val2)!({$[x; y; (::)]}[1b;(avg;`val1)];{$[x; y; (::)]}[1b; (sum;`val2)])];
k1 avg_val1 sum_val2
1 20.0 94
2 55.0 138
3 90.0 114
而是将 1b 置于状态,我想像这样放置真实状态:
res:?[t;();(enlist`k1)!enlist`k1;(`avg_val1;`sum_val2)!({$[x; y; (::)]}[(in;`k2;2 3 4i);(avg;`val1)];{$[x; y; (::)]}[(in;`k2;2 3i); (sum;`val2)])];
但它会给出“类型”错误,因为查询将是 k1 的第一组,而 k2 将是列表。所以条件也不对。
我想知道什么是最好的解决方案。 可能有更好的方法来解决同样的问题。请帮助我。
谢谢你。