KDB中的条件WHERE子句?

卡林

完整查询:

{[tier;company;ccy; startdate; enddate] select Deal_Time, Deal_Date from DEALONLINE_REMOVED where ?[company = `All; 1b; COMPANY = company], ?[tier = `All;; TIER = tier], Deal_Date within(startdate;enddate), Status = `Completed, ?[ccy = `All;1b;CCY_Pair = ccy]}

特殊查询:

where ?[company = `All; 1b; COMPANY = company], ?[tier = `All; 1b; TIER = tier],

该查询试图执行的操作是获取下拉菜单的viewstate。

如果下拉选择为“全部”,则where子句即companyortier无效,并显示所有公司或层。

我不确定上面的查询是否正确,因为在KDB仪表板上显示它们时我得到了奇怪的图表。

DanDan4561

我建议使用功能性qSQL来重组您的函数以使用where子句

在您的情况下,您需要能够基于某些输入进行过滤,如果其“全部”不进行过滤,则对该输入进行其他过滤。这样的事情可能会起作用。

/Define sample table
DEALONLINE_REMOVED:([]Deal_time:10#.z.p;Deal_Date:10?.z.d;Company:10?`MSFT`AAPL`GOOGL;TIER:10?`1`2`3)

/New function which joins to where clause 
{[company;tier]
  wc:();
  if[not company=`All;wc:wc,enlist (=;`Company;enlist company)];
  if[not tier=`All;wc:wc,enlist (=;`TIER;enlist tier)];
  ?[DEALONLINE_REMOVED;wc;0b;()]
}[`MSFT;`2]

如果将输入替换为“全部”,则将返回所有内容。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章