DB2-LUW中的Regrex查询

DB2-LUW中的Regrex查询,db2,db2-luw,Db2,Db2 Luw,我需要一个regrex查询来匹配任何具有给定字符的字符串。所以我试着举个例子 SELECT wt.CHGUSER FROM "CDB"."WTBALL" wt where REGEXP_LIKE (wt.CHGUSER, '^\d*115*$'); 因此,我希望获取所有字符串,每个字符串之间有115个。我尝试了许多组合,但我得到了空列或奇怪的组合。关于- REGEXP_LIKE (wt.CHGUSER, '^*\d115\d*$'); 你确定你需要正则表达式吗?你写“所有的字符串在每个字符

我需要一个regrex查询来匹配任何具有给定字符的字符串。所以我试着举个例子

SELECT wt.CHGUSER FROM "CDB"."WTBALL" wt where  REGEXP_LIKE (wt.CHGUSER, '^\d*115*$');
因此,我希望获取所有字符串,每个字符串之间有115个。我尝试了许多组合,但我得到了空列或奇怪的组合。

关于-

REGEXP_LIKE (wt.CHGUSER, '^*\d115\d*$');

你确定你需要正则表达式吗?你写“所有的字符串在每个字符串之间的某个地方有115个”,但是测试一个在某个地方有“115”的全数字字符串。。。 顺便说一句,这也可以在没有正则表达式的情况下完成:

WHERE LOCATE('115', wt.CHGUSER) > 0
  AND TRANSLATE(wt.CHGUSER, '', '0123456789') --if You really want to test all-digit string
为什么不使用本机的“LIKE”表达式?
其中wt.CHGUSER类似于“%115%”

这将给出与regexp不同的结果,因为只要前面和后面都有一个数字,表达式就在寻找“115”。与您的问题相匹配的更通用的regexp是
'.*115.*'

我用
regexp_-LIKE(wt.CHGUSER,'^\d*115\d*$)解决了它