关于mysql:MySQL-中的反斜杠-\\真是太坑了

53次阅读

共计 2492 个字符,预计需要花费 7 分钟才能阅读完成。

在 MySQL 中有很多特殊符号都是相当恶心的,比方字符串中有单引号(’)、双引号(”)、反斜杠(\)等等,同学们能够先脑补一下可能会呈现啥问题?

在咱们平时操作 SQL 中,一不注意这些符号就会给你背上一口锅。

你还别不信,听叔一句劝,这里的水很深,有些货色,你把握不住…《潘嘎之交》好了,明天咱们就一起针对最膈应人的反斜杠(\),来看看都有哪些坑。

一、INSERT 语句中有反斜杠(\)

1、理论测试

咱们用上面这些 SQL 来测试一下反斜杠(\)在 INSERT 语句中会是啥样?

INSERT INTO `demo0526` (`id`, `text`) VALUES (null, 'D:\ 陈哈哈 \ 加班');
INSERT INTO `demo0526` (`id`, `text`) VALUES (null, 'D:\\ 陈哈哈 \\ 加班');
INSERT INTO `demo0526` (`id`, `text`) VALUES (null, 'D:\\\ 陈哈哈 \\\ 加班');
INSERT INTO `demo0526` (`id`, `text`) VALUES (null, 'D:\\\\ 陈哈哈 \\\\ 加班');
INSERT INTO `demo0526` (`id`, `text`) VALUES (null, 'D:\\\\\ 陈哈哈 \\\\\ 加班');

插入后的后果:

mysql> select * from demo0526;
+----+-----------------------+
| id | text                  |
+----+-----------------------+
|  1 | D: 陈哈哈加班          |
|  2 | D:\ 陈哈哈 \ 加班        |
|  3 | D:\ 陈哈哈 \ 加班        |
|  4 | D:\\ 陈哈哈 \\ 加班      |
|  5 | D:\\ 陈哈哈 \\ 加班      |
+----+-----------------------+
5 rows in set (0.00 sec)

咱们发现后果如下:

当字符串中有 1 个反斜杠,插入后算 0 个。

当字符串中有 2 个反斜杠,插入后算 1 个。

当字符串中有 3 个反斜杠,插入后算 1 个。

当字符串中有 4 个反斜杠,插入后算 2 个。

当字符串中有 5 个反斜杠,插入后算 2 个。

2、是啥原理?

起初发现,起因其实很简略,在 MySQL 中,反斜杠在字符串中是属于转义字符,通过语法解析器解析时会进行一次本义,所以当咱们 insert 反斜杠(\)字符时,如 insert“\”在数据库中最终只会存储 ””,第一个反斜杠(\)被当做转义字符解决。

同理,像这种 D:\ 陈哈哈 \ 加班 字符串,语法解析器解析到第三个反斜杠(\)时,又会把它当做下一个转义字符进行解决,因而 D:\ 陈哈哈 \ 加班入库后变成了 D:\ 陈哈哈 \ 加班。

所以咱们在代码中解决插入语句碰到反斜杠时,留神 \ 是否曾经改成 \,否则入库后字符串会不统一。

二、SELECT 查问反斜杠(\)

1、理论测试

咱们还是沿用下面的表数据,间接用 like 含糊匹配来测试一下。

mysql> select * from demo0526;
+----+-----------------------+
| id | text                  |
+----+-----------------------+
|  1 | D: 陈哈哈加班          |
|  2 | D:\ 陈哈哈 \ 加班        |
|  3 | D:\ 陈哈哈 \ 加班        |
|  4 | D:\\ 陈哈哈 \\ 加班      |
|  5 | D:\\ 陈哈哈 \\ 加班      |
+----+-----------------------+

咱们先用单个反斜杠和两个反斜杠看看能查到啥玩意儿

mysql> SELECT * from demo0526 where text like '%\%';
Empty set (0.00 sec)

mysql> SELECT * from demo0526 where text like '%\\%';
Empty set (0.00 sec)

啊!!咱们用 like ‘%%’、like ‘%\%’ 查问后发现都查不到数据,纳尼?下面的我白学了吗?

别着急,我会通知你 SELECT 语句中四个反斜杠(\)代表一个么?呀,我赶快换成 like ‘%\%’ 试一试。

mysql> SELECT * from demo0526 where text like '%\\\\%';
+----+-----------------------+
| id | text                  |
+----+-----------------------+
|  2 | D:\ 陈哈哈 \ 加班        |
|  3 | D:\ 陈哈哈 \ 加班        |
|  4 | D:\\ 陈哈哈 \\ 加班      |
|  5 | D:\\ 陈哈哈 \\ 加班      |
+----+-----------------------+
4 rows in set (0.00 sec)

喔?那我如果查问表中带有两个反斜杠(\)的数据,岂不是要 like 八个。。。。别拦我,我看看 tm 是谁设计的这规定。

mysql> SELECT * from demo0526 where text like '%\\\\\\\\%';
+----+-----------------------+
| id | text                  |
+----+-----------------------+
|  4 | D:\\ 陈哈哈 \\ 加班      |
|  5 | D:\\ 陈哈哈 \\ 加班      |
+----+-----------------------+
2 rows in set (0.00 sec)

2、又是啥原理?

原来在 mysql 的 like 语法中,like 后边的字符串除了会在语法解析时本义一次外,还会在正则匹配时进行第二次的本义。因而如果冀望最终匹配到 ””,就要反本义两次,也就是由 ”\” 到 ”\” 再到 ””。

如果是一般的准确查问(=),则无需第二次的正则本义,和 INSERT 语句一样。

mysql> SELECT * from demo0526 where text = '\\\\';
+----+------+
| id | text |
+----+------+
|  7 | \\   |
+----+------+
1 row in set (0.00 sec)

总结

好了,看到这里同学们有什么感触呢?是不是发现 MySQL 中还是存在很多不不便的语法,提高空间还很大呀~~

在日常工作中,也会常常碰到这种符号引发的问题,尤其是用户在界面填写的数据,倡议要做相干限定,明确哪些符号不容许。

作者:陈哈哈
原文链接:https://blog.csdn.net/qq_3939…

正文完
 0