ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

php – 在mySQL regexp中使用多个值

2019-07-21 21:31:00  阅读:266  来源: 互联网

标签:php mysql regex


我有一个问题:

SELECT * from arrc_Voucher WHERE VoucherNbr REGEXP "^1002"

这很有效 – VoucherNbr是一个16个字符的代码,此查询查找前四位数为1002的所有记录.

现在我需要扩展它,我对正则表达式不是很好.我需要能够找到前四位数字是1002,1010,2015或3156的所有记录.如果这些是完整的数字,我只使用IN:

SELECT * from arrc_Voucher WHERE VoucherNbr IN (1002, 1010, 2015, 3156)

但是因为我需要以这些数字开头的代码,所以这不起作用.任何人都可以帮助我扩展正则表达式,以便它可以寻找多个值?为了使它更有趣,这些值不能被硬编码;它们存储在数据库配置表中,并由自定义php函数以逗号分隔的字符串形式返回.所以我需要能够编写查询,以便regexp可以获取返回的字符串的值,而不是我提到的特定的四个数字.

解决方法:

您可以使用以下正则表达式,使用the union operator(|).

REGEXP "^(1002|1010|2015|3156)"

标签:php,mysql,regex
来源: https://codeday.me/bug/20190721/1496095.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有