如何忽略错误1139(具有错误模式的REGEX运算符)?

时间:2012-10-31 11:19:38

标签: mysql regex

考虑下表:

mysql> select * from test;
+---------+
| col     |
+---------+
| ^test$  |
| tes$()t |
| X$%[    |
| test$   |
| ^test   |
| test    |
| [       |
+---------+
7 rows in set (0.04 sec)

它包含有效和无效的模式。

如果我这样做:

mysql> select * from test where 'test' regexp col;
+--------+
| col    |
+--------+
| ^test$ |
| test$  |
| ^test  |
| test   |
+--------+
4 rows in set (0.04 sec)

我得到的所有行的模式都匹配'test',所有其他行(包括无效模式)都被忽略。

现在,如果我直接执行无效请求,则会出现模式语法错误:

mysql> select * from test where 'test' regexp '[';
ERROR 1139 (42000): Got error 'brackets ([ ]) not balanced' from regexp

有没有办法(没有另一个表)强制MySQL忽略这些错误(例如会给出一个空的结果)?

2 个答案:

答案 0 :(得分:0)

select * from test where 'test' like '[';

答案 1 :(得分:0)

Okey我找到了一个有效的解决方案,这很棘手但是工作:

SELECT * FROM test WHERE 'test' REGEXP RIGHT(CONCAT(col, '['), LENGTH('['));

用你的正则表达式替换'['。如果您允许客户使用regexp,则可能很有用。