【MySQL】字符串截取之SUBSTRING_INDEX和【MySQL】字符串四則運算

substring_index(str,delim,count)java

      str:要處理的字符串mysql

      delim:分隔符sql

      count:計數數據庫

例子:str=www.google.com數組

1.count是正數,那麼就是從左往右數,第N個分隔符的左邊的所有內容函數

SELECT SUBSTRING_INDEX('www.google.com','.',1);

      結果是:wwwgoogle

SELECT SUBSTRING_INDEX('www.google.com','.',2);

      結果是:www.googlespa

     

2.count是負數,那麼就是從右邊開始數,第N個分隔符右邊的全部內容,如:.net

SELECT SUBSTRING_INDEX('www.google.com','.',-2);

      結果爲:google.com3d

    若是我呀中間的的google怎麼辦?

     很簡單的,兩個方向:

      從右數第二個分隔符的右邊所有,再從左數的第一個分隔符的左邊:

SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('www.google.com','.',-2),'.',1);

      結果爲:google

總結:SUBSTRING_INDEX能夠理解爲java裏面按照分隔符使用split進行分組,從所得數組的下標+1處一直到開始算起的位置的全部內容即爲最終結果,若是count 不等於0,那麼即便str中沒有找到delim分隔,那麼返回的結果就是str自己,即只要count!=0,那麼返回的最差結果也是str自己(沒有找到一個delim分隔符...的狀況)

例如:

(1)

SELECT SUBSTRING_INDEX('www.google.com','AAA',-1);

SELECT SUBSTRING_INDEX('www.google.com','AAA',-99);

二者的結果都爲:www.google.com

(2)在項目中利用CONCAT來作字符串合併,發現一個一個有意思的事情,

SELECT  CONCAT(SUBSTRING_INDEX('www.google.com','.',1),'-','AAAABB')

結果爲:www-AAAABB

(3)

SELECT  CONCAT(SUBSTRING_INDEX('www.google.com','AAA',1),'-','AAAABB')

結果爲:www.google.com-AAAABB

(4)

SELECT  CONCAT(SUBSTRING_INDEX('www.google.com','AAA',1)-1,'-','AAAABB')

結果爲:-1-AAAABB

結果咋這樣呢?發現Mysql的字符串在參與運算的時候頗有意思:

如下內容摘自:https://www.jianshu.com/p/2ab2c0dc3cb5

mysql之字符串進行運算或大小比較

在mysql當中,字符串類型間進行加減乘除運算的時候,若是字符串以數字開頭,則會截取字符串以數字開頭的那一部分數字進行運算,若是字符串沒將誒有以數字開頭數字,那麼就只能截取的數值爲0,那麼進行加減的時候結果都是0,進行乘除的時候結果都是NULL(即若是以字符串開頭,則會從數字一直截取到非數字爲止;若是不以數字開頭,那麼取0)

以下幾個結果說明問題:

mysql> select '1a'+'1b';//字符串分別以1開頭,因此運算的時候,分別爲1,結果爲1+1=2
+-----------+
| '1a'+'1b' |
+-----------+
|         2 |
+-----------+
1 row in set, 2 warnings (0.00 sec)
mysql> select '2a'-'1b';//字符串分別以2和1開頭,因此結果爲2-1=1
+-----------+
| '2a'-'1b' |
+-----------+
|         1 |
+-----------+
1 row in set, 2 warnings (0.00 sec)
mysql> select '1a'/'2b';//字符串分別以1和2開頭,因此結果爲:1/2=0.5
+-----------+
| '1a'/'2b' |
+-----------+
|       0.5 |
+-----------+
1 row in set, 2 warnings (0.00 sec)
mysql> select 'a'/'b';//字符串分別以'a'和'b'開頭,因此結果爲0/0=NULL
+---------+
| 'a'/'b' |
+---------+
|    NULL |
+---------+
1 row in set, 3 warnings (0.00 sec)
mysql> select 'a' - 'b';//字符串分別以'a'和'b'開頭,結果爲0-0=0
+-----------+
| 'a' - 'b' |
+-----------+
|         0 |
+-----------+
1 row in set, 2 warnings (0.00 sec)
mysql> select 'a' + 'b';//字符串分別以'a'和'b'開頭,結果爲0+0=0
+-----------+
| 'a' + 'b' |
+-----------+
|         0 |
+-----------+
1 row in set, 2 warnings (0.00 sec)

若是一個字符串以數字開頭,後面有非數字和數字組合的話,在進行運算的時候,會省略掉非數字和數字組合那一段,也就是隻會截取開頭的數字

mysql> select '2015-2-1' - '2015-1-1';////字符串分別以'2015'和'2015'開頭,結果爲2015-2015=2015
+-------------------------+
| '2015-2-1' - '2015-1-1' |
+-------------------------+
|                       0 |
+-------------------------+
1 row in set, 2 warnings (0.00 sec)

以上至關於2015-2015=0

mysql當字符串進行大小比較的時候

mysql> select '2015-2-1' > '2015-1-1';
+-------------------------+
| '2015-2-1' > '2015-1-1' |
+-------------------------+
|                       1 |
+-------------------------+
1 row in set (0.00 sec)
mysql> select '2015-2-1' < '2015-1-1';
+-------------------------+
| '2015-2-1' < '2015-1-1' |
+-------------------------+
|                       0 |
+-------------------------+
1 row in set (0.00 sec)

在這裏很是奇怪,'2015-2-1' - '2015-1-1' = 0,爲何大小比較的時候會有大小之分呢?

原來對於數字與非數字混合的字符串,在進行大小比較的時候,若是兩字符串長度相等,那麼兩字符串就會比較相同位置的字符,比較時若字符是數字,則直接比較,若字符是非數字那麼會轉換爲ascii碼進行比較,若在某位置上已經有大小之分,那麼就不會再進行比較。

mysql> select '2017-03-20 15:27:49' > '2017-03-20 15:27:48';
+-----------------------------------------------+
| '2017-03-20 15:27:49' > '2017-03-20 15:27:48' |
+-----------------------------------------------+
|                                             1 |
+-----------------------------------------------+
1 row in set (0.00 sec)

看起來像日期的字符串能夠用date_format函數提取當中的年月日,看以下:

mysql> select date_format('2017/03/20 15:27:49','%Y') 年,date_format('2017/03/20 15:27:49','%c') 月,date_format('2017/03/20 15:27:49','%d') 日;
+------+------+------+
| 年   | 月   | 日   |
+------+------+------+
| 2017 | 3    | 20   |
+------+------+------+
1 row in set (0.00 sec)

非數字字符在比較大小的時候,就例如:

mysql> select 'a' < 'b';
+-----------+
| 'a' < 'b' |
+-----------+
|         1 |
+-----------+
1 row in set (0.00 sec)

當中的字母會轉成ascii碼,再進行比較,以上是單字母字符串比較,若是是多字母數字混合字符串比較呢?

mysql> select '1c' > 'bc';

+-------------+
| '1c' > 'bc' |
+-------------+
|           0 |
+-------------+
1 row in set (0.00 sec)
mysql> select '1yz' > 'abc999';
+------------------+
| '1yz' > 'abc999' |
+------------------+
|                0 |
+------------------+
1 row in set (0.00 sec)

其實從上面的結果大概能夠猜想獲得,爲讓解釋更清晰更有說服力,再看下圖:

mysql> select ascii('1c'),ascii('bc');
+-------------+-------------+
| ascii('1c') | ascii('bc') |
+-------------+-------------+
|          49 |          98 |
+-------------+-------------+
1 row in set (0.00 sec)
mysql> select ascii('1yz'),ascii('abc999');
+--------------+-----------------+
| ascii('1yz') | ascii('abc999') |
+--------------+-----------------+
|           49 |              97 |
+--------------+-----------------+
1 row in set (0.00 sec)

字符串大小比較的時候,會從左向右將兩個字符串第一個不相等的兩個字符的ascii碼的比較結果做爲最終結果

有時候咱們須要直接用MySQL的字符串函數截取字符,畢竟用程序截取(如PHP)還得先寫個腳本鏈接數據庫之類的,因此在這裏作一個記錄,但願對你們有用。 

MySQL截取字符串函數

一、從左開始截取字符串 
left(str, length) 
說明:left(被截取字段,截取長度) 
例:

select left(content,200) as abstract from my_content_t

二、從右開始截取字符串 
right(str, length) 
說明:right(被截取字段,截取長度) 
例:

select right(content,200) as abstract from my_content_t

三、截取字符串 

substring(str, pos) 
substring(str, pos, length) 
說明:substring(被截取字段,從第幾位開始截取) 
substring(被截取字段,從第幾位開始截取,截取長度) 
例:

select substring(content,5) as abstract from my_content_t 
select substring(content,5,200) as abstract from my_content_t

(注:若是位數是負數 如-5 則是從後倒數位數,到字符串結束或截取的長度) 

四、按關鍵字截取字符串 
substring_index(str,delim,count) 
說明:substring_index(被截取字段,關鍵字,關鍵字出現的次數) 
例:

select substring_index("blog.jb51.net",".",2) as abstract from my_content_t

結果:blog.jb51 

相關文章
相關標籤/搜索