国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

MySQL 字符串截取相關(guān)函數(shù)小結(jié)

2024-07-25 19:08:16
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

文中給大家介紹MySQL 字符串截取相關(guān)函數(shù),具體內(nèi)容如下所示:

在工作中,可能需要將某些字段按某個(gè)分割符組成一個(gè)字符串作為字段值存取到數(shù)據(jù)庫(kù)表中,比如某個(gè)任務(wù)對(duì)應(yīng)三個(gè)結(jié)果,分別存儲(chǔ)在不同的數(shù)據(jù)表中,這時(shí)可以將這三個(gè)不同表的主鍵按照約定的順序進(jìn)行組合(主鍵a:主鍵b:主鍵c)。當(dāng)需要分別去查任務(wù)對(duì)應(yīng)類(lèi)別的詳情信息時(shí),可以截取特定位置的字符串(主鍵b) join 表b進(jìn)行操作。正好最近也遇到這塊操作,特意將 MySQL 字符串截取的相關(guān)函數(shù)做一個(gè)梳理,以便今后回顧。

一、left(str, len)

返回字符串 str 自左數(shù)的 len 個(gè)字符。如果任一參數(shù)為 NULL,則返回 NULL。

mysql> select left('shinejaie', 5);+---------------------------------------------------------+| left('shinejaie', 5)                  |+---------------------------------------------------------+| shine                          |+---------------------------------------------------------+1 row in set (0.00 sec)

二、right(str, len)

返回 str 右邊末 len 位的字符。如果有的參數(shù)是 NULL 值,則返回 NULL。

mysql> select right('shinejaie', 4);+---------------------------------------------------------+| right('shinejaie', 4)                  |+---------------------------------------------------------+| jaie                          |+---------------------------------------------------------+1 row in set (0.00 sec)

三、substring_index(str, delim, count)

返回 str 中第 count 次出現(xiàn)的分隔符 delim 之前的子字符串。如果 count 為正數(shù),將最后一個(gè)分隔符左邊(因?yàn)槭菑淖髷?shù)分隔符)的所有內(nèi)容作為子字符串返回;如果 count 為負(fù)值,返回最后一個(gè)分隔符右邊(因?yàn)槭菑挠覕?shù)分隔符)的所有內(nèi)容作為子字符串返回。在尋找分隔符時(shí),函數(shù)對(duì)大小寫(xiě)是敏感的。如果在字符串 str 中找不到 delim 參數(shù)指定的值,就返回整個(gè)字符串。

mysql> select substring_index('home.cnblogs.com', '.', 2);+---------------------------------------------------------+| substring_index('home.cnblogs.com', '.', 2)       |+---------------------------------------------------------+| home.cnblogs                      |+---------------------------------------------------------+1 row in set (0.00 sec)mysql> select substring_index('home.cnblogs.com', '/', 2);+---------------------------------------------------------+| substring_index('home.cnblogs.com', '/', 2)       |+---------------------------------------------------------+| home.cnblogs.com                    |+---------------------------------------------------------+1 row in set (0.00 sec)

四、substring() 與 substr() ---> substring(str, pos)、substring(str from pos)、substring(str, pos, len)、substring(str from pos for len)

在以上4種函數(shù)變種形式中,沒(méi)有 len 參數(shù)的函數(shù)形式會(huì)返回自 str 中位置 pos 處之后的子字符串;有 len 參數(shù)的函數(shù)形式會(huì)返回自 str 中位置 pos 處之后,長(zhǎng)度為 len 的子字符串。使用 FROM 的函數(shù)形式則是采用的標(biāo)準(zhǔn)的 SQL 語(yǔ)法。pos 參數(shù)也可能取負(fù)值,在這種情況下,取字符串的方式是從字符串 str 的末尾向前(而非從前往后),從這種逆向順序的 pos 處開(kāi)始取字符串。另外,負(fù)值的 pos 參數(shù)可用于任何形式的 substring() 函數(shù)中。

mysql> select substring('shinejaie', 6);+---------------------------------------------------------+| substring('shinejaie',6)                |+---------------------------------------------------------+| jaie                          |+---------------------------------------------------------+1 row in set (0.00 sec)mysql> select substr('shinejaie' from 6);+---------------------------------------------------------+| substr('shinejaie' from 6)               |+---------------------------------------------------------+| jaie                          |+---------------------------------------------------------+1 row in set (0.00 sec)mysql> select substring('shinejaie', -9, 5);+---------------------------------------------------------+| substring('shinejaie', -9, 5)              |+---------------------------------------------------------+| shine                          |+---------------------------------------------------------+1 row in set (0.00 sec)

五、trim([{both | leading | trailing} [remstr] form] str)

將字符串 str去除 remstr 所指定的前綴或后綴,返回結(jié)果字符串。如果沒(méi)有指定標(biāo)識(shí)符both、leading,或trailing,則默認(rèn)采用 both,即將前后綴都刪除。remstr 其實(shí)是個(gè)可選參數(shù),如果沒(méi)有指定它,則刪除的是空格。

mysql> select trim(' shinejaie  ');+---------------------------------------------------------+| trim(' shinejaie  ')                 |+---------------------------------------------------------+| shinejaie                        |+---------------------------------------------------------+1 row in set (0.00 sec)mysql> select trim(leading 'cn_' from 'cn_shinejaiecn_');+---------------------------------------------------------+| trim(leading 'cn_' from 'cn_shinejaiecn_')       |+---------------------------------------------------------+| shinejaiecn_                      |+---------------------------------------------------------+1 row in set (0.00 sec)mysql> select trim(both 'cn_' from 'cn_shinejaiecn_');+---------------------------------------------------------+| trim(both 'cn_' from 'cn_shinejaiecn_')         |+---------------------------------------------------------+| shinejaie                        |+---------------------------------------------------------+1 row in set (0.00 sec)mysql> select trim(trailing 'cn_' from 'cn_shinejaiecn_');+---------------------------------------------------------+| trim(trailing 'cn_' from 'cn_shinejaiecn_')       |+---------------------------------------------------------+| cn_shinejaie                      |+---------------------------------------------------------+1 row in set (0.00 sec)

總結(jié)

以上所述是小編給大家介紹的MySQL 字符串截取相關(guān)函數(shù)小結(jié),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MYSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 兰州市| 通江县| 天水市| 二连浩特市| 阜宁县| 洛隆县| 漠河县| 健康| 彩票| 濮阳县| 浦县| 陇南市| 菏泽市| 靖州| 修水县| 孟州市| 龙陵县| 布尔津县| 金堂县| 张掖市| 腾冲县| 云阳县| 石棉县| 延长县| 高陵县| 桃园市| 富平县| 襄城县| 沧州市| 石嘴山市| 吴旗县| 嘉鱼县| 霞浦县| 东辽县| 贡觉县| 平湖市| 镇康县| 广饶县| 宜丰县| 遂昌县| 龙海市|