日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

.net mysql字符串截取_【MySQL】字符串截取之SUBSTRING_INDEX和【MySQL】字符串四则运算...

發布時間:2023/12/4 数据库 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 .net mysql字符串截取_【MySQL】字符串截取之SUBSTRING_INDEX和【MySQL】字符串四则运算... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

substring_index(str,delim,count)

str:要處理的字符串

delim:分隔符

count:計數

例子:str=www.google.com

1.count是正數,那么就是從左往右數,第N個分隔符的左邊的全部內容

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

結果是:www

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

結果是:www.google

2.count是負數,那么就是從右邊開始數,第N個分隔符右邊的所有內容,如:

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

結果為:google.com

如果我呀中間的的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的字符串在參與運算的時候很有意思:

MYSQL截取函數:

1、從左開始截取字符串

left(str, length)

說明:left(被截取字段,截取長度)

例:select left(content,200) as abstract from my_content_t

2、從右開始截取字符串

right(str, length)

說明:right(被截取字段,截取長度)

例:select right(content,200) as abstract from my_content_t

3、截取字符串

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 則是從后倒數位數,到字符串結束或截取的長度)

4、按關鍵字截取字符串

substring_index(str,delim,count)

說明:substring_index(被截取字段,關鍵字,關鍵字出現的次數)

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

結果:blog.jb51

(注:如果關鍵字出現的次數是負數 如-2 則是從后倒數,到字符串結束)

函數簡介:

SUBSTRING(str,pos) , SUBSTRING(str?FROM?pos) SUBSTRING(str,pos,len) , SUBSTRING(str?FROM?pos?FOR?len)

不帶有len?參數的格式從字符串str返回一個子字符串,起始于位置?pos。帶有len參數的格式從字符串str返回一個長度同len字符相同的子字符串,起始于位置?pos。 使用 FROM的格式為標準 SQL 語法。也可能對pos使用一個負值。假若這樣,則子字符串的位置起始于字符串結尾的pos?字符,而不是字符串的開頭位置。在以下格式的函數中可以對pos?使用一個負值。

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截取字符串函數

1、從左開始截取字符串

left(str, length)

說明:left(被截取字段,截取長度)

例:

select left(content,200) as abstract from my_content_t

2、從右開始截取字符串

right(str, length)

說明:right(被截取字段,截取長度)

例:

select right(content,200) as abstract from my_content_t

3、截取字符串

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 則是從后倒數位數,到字符串結束或截取的長度)

4、按關鍵字截取字符串

substring_index(str,delim,count)

說明:substring_index(被截取字段,關鍵字,關鍵字出現的次數)

例:

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

結果:blog.jb51

總結

以上是生活随笔為你收集整理的.net mysql字符串截取_【MySQL】字符串截取之SUBSTRING_INDEX和【MySQL】字符串四则运算...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。