首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >DB2-LUW中的Regrex查询

DB2-LUW中的Regrex查询
EN

Stack Overflow用户
提问于 2019-09-06 15:44:39
回答 3查看 56关注 0票数 0

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

代码语言:javascript
复制
SELECT wt.CHGUSER FROM "CDB"."WTBALL" wt where  REGEXP_LIKE (wt.CHGUSER, '^\d*115*$');

因此,我希望获取每个字符串之间有115个字符串的所有字符串。我尝试了许多组合,但我得到了空列或奇怪的组合。

EN

回答 3

Stack Overflow用户

发布于 2019-09-09 15:55:59

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

代码语言:javascript
复制
WHERE LOCATE('115', wt.CHGUSER) > 0
  AND TRANSLATE(wt.CHGUSER, '', '0123456789') --if You really want to test all-digit string
票数 0
EN

Stack Overflow用户

发布于 2019-09-09 23:28:24

为什么不使用原生的"LIKE“表达式呢?where wt.CHGUSER like '%115%'这会给出不同于正则表达式的结果,因为只要前面和后面都有一个数字,你的表达式就会查找'115‘。与您的问题匹配的更通用的正则表达式应该是'.*115.*'

票数 0
EN

Stack Overflow用户

发布于 2019-09-06 16:06:20

那-

代码语言:javascript
复制
REGEXP_LIKE (wt.CHGUSER, '^*\d115\d*$');
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57817760

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档