首頁 > 軟體

MySQL裡的反斜槓(\\)的使用

2023-02-05 14:03:36

一、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:\陳哈哈\加班      |
+----+-----------------------+
5 rows in set (0.00 sec)

我們先用單個反斜槓和兩個反斜槓看看能查到啥玩意兒

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裡的反斜槓(\)的使用的文章就介紹到這了,更多相關MySQL 反斜槓內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com