考虑下表:
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忽略这些错误(例如会给出一个空的结果)?
答案 0 :(得分:0)
select * from test where 'test' like '[';
答案 1 :(得分:0)
Okey我找到了一个有效的解决方案,这很棘手但是工作:
SELECT * FROM test WHERE 'test' REGEXP RIGHT(CONCAT(col, '['), LENGTH('['));
用你的正则表达式替换'['。如果您允许客户使用regexp,则可能很有用。