在mySQL regexp中使用多个值

Emm*_*myS 3 php regex mysql

我有一个问题:

SELECT * from arrc_Voucher WHERE VoucherNbr REGEXP "^1002"
Run Code Online (Sandbox Code Playgroud)

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

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

SELECT * from arrc_Voucher WHERE VoucherNbr IN (1002, 1010, 2015, 3156)
Run Code Online (Sandbox Code Playgroud)

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

Yet*_*eek 6

您可以使用union运算符(|)使用以下正则表达式.

REGEXP "^(1002|1010|2015|3156)"
Run Code Online (Sandbox Code Playgroud)


ike*_*ami 5

VoucherNbr REGEXP "^(1002|1010|2015|3156)"
Run Code Online (Sandbox Code Playgroud)

不那么可读,但回溯较少:

VoucherNbr REGEXP "^(10(02|10)|2015|3156)"
Run Code Online (Sandbox Code Playgroud)

您当然也可以执行以下操作:

LEFT(VoucherNbr, 4) IN (1002, 1010, 2015, 3156)
Run Code Online (Sandbox Code Playgroud)

更新:添加第二和第三个解决方案.