KDB中的条件WHERE子句?

KDB中的条件WHERE子句?,kdb,Kdb,完整查询: {[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;

完整查询:

{[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],
特定查询:

{[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子句即
公司
无效,并显示所有公司或层


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

我建议您重新构造函数,以使用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]

如果将输入替换为“All”,您将看到所有内容都返回了

查询的完整功能选择如下所示:

whcl:{[tier;company;ccy;startdate;enddate]
 wc:(enlist (within;`Deal_Date;(enlist;startdate;enddate))),(enlist (=;`Status;enlist `Completed)),
 $[tier=`All;();enlist (=;`TIER;enlist tier)],
 $[company=`All;()enlist (=;`COMPANY;enlist company)],
 $[ccy=`All;();enlist (=;`CCY_Pair;enlist ccy)];
 ?[`DEALONLINE_REMOVED;wc;0b;`Deal_Time`Deal_Date!`Deal_Time`Deal_Date]
}
第一部分在where子句中指定日期范围和
status=`Completed

wc:(enlist (within;`Deal_Date;(enlist;startdate;enddate))),(enlist (=;`Status;enlist `Completed)),
接下来,这些条件中的每一个都会检查TIER、COMPANY和CCY_Pair列筛选的'All'。然后,当指定特定的层、公司或CCY_对时,它将这些连接到where子句。(否则,将在上加入空列表):

最后,select语句以如下函数形式调用,wc作为where子句:


?[`DEALONLINE\u已删除;wc;0b;`Deal\u Time`Deal\u Date!`Deal\u Time`Deal\u Date]

您想过使用解析树吗?然后,您可以使用if语句来检查公司和层级的价值。如果它们等于您可以设置的所有值,则将它们添加到解析树中,并构建函数查询。有关详细信息,请参阅链接,或者使用parse命令帮助构建查询,例如,
parse“从t中选择c1,c2,其中c1=
IBM,c2>23”`您好,Matt,代码结构中有一些内容。我不建议显式定义像“x”这样的变量,因为它是一个保留名称-。此外,在这种情况下,您不需要使用$if-else,并且在默认情况下使用$时,它将始终输出一些内容,因此不需要“:”x、y、z不是保留名称(
.Q.res
),也不是保留单字母命名空间的一部分。对于简单函数,隐式x,y,z的使用是可以接受的,同样,显式工作的习惯也是可以接受的。为了最大限度地提高可读性,在简洁和冗长的代码之间取得平衡是很重要的。