在KDB SQL的like查询中转义*字符的方法咨询
解决KDB中匹配含连续*字符的字符串问题
我之前也碰到过这个头疼的问题!KDB的like操作符里*是通配符(匹配任意长度的字符),所以直接写"foo**bar"会被解析成foo后面跟任意字符再跟bar,完全不是你要的字面匹配。下面给你两种可行的解决办法:
方法1:正确转义通配符*
KDB里like的转义字符是反斜杠\,但因为Q语言中双引号字符串里的反斜杠本身需要转义(用来表示一个字面的反斜杠),所以你需要写两个反斜杠来转义一个*。
比如你要匹配foo**bar,查询语句应该写成:
select from table where column like "foo\\*\\*bar"
这里的\\*会被解析成字面的*,这样like就会准确匹配包含foo**bar的字符串了。
方法2:用instr函数跳过通配符处理
如果你觉得转义太麻烦,直接用instr函数更简单——它是用来查找子字符串在目标字符串中的位置,完全不涉及通配符,直接按字面匹配:
select from table where instr[column; "foo**bar"] > 0
只要column里包含foo**bar这个子串,instr就会返回它的起始位置(大于0),这样就能筛选出你要的行。
我个人更推荐第二种方法,尤其是当需要匹配的特殊字符比较多的时候,不用纠结转义规则,直接用字面子串匹配更省心。
内容的提问来源于stack exchange,提问作者wwarby




