共计 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…