考虑下表:
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)
我得到模式匹配“测试”的所有行,而所有其他行(包括无效模式)都被忽略。
现在,如果我直接执行无效请求,则会收到模式语法错误:
mysql> select * from test where 'test' regexp '[';
ERROR 1139 (42000): Got error 'brackets ([ ]) not balanced' from regexp
有没有办法(没有另一个表)强制 MySQL 忽略这些错误(例如会给出一个空结果)?