繁体   English   中英

MySQL正则表达式匹配所有字符

[英]MySql regexp match all characters

我在MySQL中匹配正则表达式,如下所示:

$this->db->where('bottom_id REGEXP', $bottom);

$ bottom的值来自一个数组:

$bottom_key = array('EG','LE','KG','IS|BO|COA|ARG|PAW|HSE','JG|KH|BR|LL|MO|RA', 'JGS|KHS|BRS|LLS|KHC|BRC|TY|MOS|RAS', 'LEO|EGS');

当我运行查询“ JG | KH | BR | LL | MO | RA”和“ JGS | KHS | BRS | LLS | KHC | BRC | TY | MOS | RAS”重复某些结果时,即从JG中选择了JGS值。

如何强制值的精确匹配,以便JG仅匹配JG而不能匹配JGS?

数据表如下所示:

|------
|id|order_id|product_id|upper_id|bottom_id|create_date|del_date|ref_no|comm_code
|------
|81|17|6151|HSA       |IS        |0000-00-00 00:00:00|2016-10-15|NULL|NULL
|82|17|7441|BHE       |IS        |0000-00-00 00:00:00|2016-09-15|NULL|NULL
|83|17|7501|MUA       |IS        |0000-00-00 00:00:00|2016-07-15|NULL|NULL
|84|17|7137|KDB       |IS        |0000-00-00 00:00:00|2016-07-07|NULL|NULL
|85|17|7137|KDD       |IS        |0000-00-00 00:00:00|2016-08-15|NULL|NULL
|86|17|6613|PAA       |KG        |0000-00-00 00:00:00|2016-10-15|NULL|NULL
|87|17|7315|CDA       |KG        |0000-00-00 00:00:00|2016-07-07|NULL|NULL
|88|17|7525|COA       |KG        |0000-00-00 00:00:00|2016-07-07|NULL|NULL
|89|17|7525|COA       |KG        |0000-00-00 00:00:00|2016-09-15|NULL|NULL
|90|17|1600|JGC       |MOS       |0000-00-00 00:00:00|2016-08-15|PD65929|NULL

采用

$bottom_key = array('^EG$','^LE$','^KG$','^(IS|BO|COA|ARG|PAW|HSE)$','^(JG|KH|BR|LL|MO|RA)$', '^(JGS|KHS|BRS|LLS|KHC|BRC|TY|MOS|RAS)$', '^(LEO|EGS)$');

正则表达式符号^表示字符串的开头, $表示字符串的结尾。

您可以通过将$放在JG(即JG $)之后来进行严格匹配,这意味着匹配的字符串应以G结尾。这应该可以解决您的问题。

您最好使用一个IN子句,而不是一个正则表达式数组。

bottom_id IN ('EG','LE','KG','IS','BO','COA','ARG','PAW','HSE','JG',...)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM