主页 > MySQL教程 > 正文

MySQL 字符串截取相关函数总结

在工作中,或许需求将某些字段按某个切割符组成一个字符串作为字段值存取到数据库表中,比方某个使命对应三个成果,别离存储在不同的数据表中,这时能够将这三个不同表的主键依照约好的次序进行组合(主键a:主键b:主键c)。当需求别离去查使命对应类别的概况信息时,能够截取特定方位的字符串(主键b) join 表b进行操作。正好最近也遇到这块操作,特意将 MySQL 字符串截取的相关函数做一个整理,以便往后回忆。


一、left(str, len)

回来字符串 str 自左数的 len 个字符。假如任一参数为 NULL,则回来 NULL。


mysql> select left('vztug.com', 5);

+---------------------------------------------------------+

| left('vztug.com', 5)                                |

+---------------------------------------------------------+

| pytho                                                   |

+---------------------------------------------------------+

1 row in set (0.00 sec)


二、right(str, len)

回来 str 右边末 len 位的字符。假如有的参数是 NULL 值,则回来 NULL。


mysql> select right('vztug.com', 4);

+---------------------------------------------------------+

| right('vztug.com', 4)                               |

+---------------------------------------------------------+

| .com                                                    |

+---------------------------------------------------------+

1 row in set (0.00 sec)


三、substring_index(str, delim, count)

回来 str 中第 count 次呈现的分隔符 delim 之前的子字符串。假如 count 为正数,将最终一个分隔符左面(由于是从左数分隔符)的一切内容作为子字符串回来;假如 count 为负值,回来最终一个分隔符右边(由于是从右数分隔符)的一切内容作为子字符串回来。在寻觅分隔符时,函数对大小写是灵敏的。假如在字符串 str 中找不到 delim 参数指定的值,就回来整个字符串。


mysql> select substring_index('www.vztug.com', '.', 2);

+---------------------------------------------------------+

| substring_index('www.vztug.com', '.', 2)            |

+---------------------------------------------------------+

| www.pythontab                                           |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select substring_index('www.vztug.com', '/', 2);

+---------------------------------------------------------+

| substring_index('www.vztug.com', '/', 2)            |

+---------------------------------------------------------+

| www.vztug.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种函数变种办法中,没有 len 参数的函数办法会回来自 str 中方位 pos 处之后的子字符串;有 len 参数的函数办法会回来自 str 中方位 pos 处之后,长度为 len 的子字符串。运用 FROM 的函数办法则是选用的规范的 SQL 语法。pos 参数也或许取负值,在这种情况下,取字符串的办法是从字符串 str 的结尾向前(而非早年往后),从这种逆向次序的 pos 处开端取字符串。别的,负值的 pos 参数可用于任何办法的 substring() 函数中。


mysql> select substring('vztug.com', 6);

+---------------------------------------------------------+

| substring('vztug.com',6)                            |

+---------------------------------------------------------+

| ntab.com                                                |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select substr('vztug.com' from 6);

+---------------------------------------------------------+

| substr('vztug.com' from 6)                          |

+---------------------------------------------------------+

| ntab.com                                                |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select substring('vztug.com', -10, 4);

+---------------------------------------------------------+

| substring('vztug.com', -10, 4)                      |

+---------------------------------------------------------+

| hont                                                    |

+---------------------------------------------------------+

1 row in set (0.00 sec)


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

将字符串 str去除 remstr 所指定的前缀或后缀,回来成果字符串。假如没有指定标识符both、leading,或trailing,则默许选用 both,行将前后缀都删去。remstr 其实是个可选参数,假如没有指定它,则删去的是空格。

mysql> select trim(' vztug.com  ');

+---------------------------------------------------------+

| trim(' vztug.com  ')                                |

+---------------------------------------------------------+

| vztug.com                                           |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select trim(leading 'www.' from 'www.vztug.com');

+---------------------------------------------------------+

| trim(leading 'www.' from 'www.vztug.com')           |

+---------------------------------------------------------+

| vztug.com                                           |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select trim(both 'www.' from 'www.vztug.com');

+---------------------------------------------------------+

| trim(both 'www.' from 'www.vztug.com')              |

+---------------------------------------------------------+

| vztug.com                                           |

+---------------------------------------------------------+

1 row in set (0.00 sec)

mysql> select trim(trailing 'www.' from 'www.vztug.com');

+---------------------------------------------------------+

| trim(trailing 'www.' from 'www.vztug.com')          |

+---------------------------------------------------------+

| www.vztug.com                                       |

+---------------------------------------------------------+

1 row in set (0.00 sec)


上一篇:MySQL使用索引优化ORDER BY排序句子
下一篇:千万条数据,Stack Overflow 是怎么完成快速分页的?

PythonTab微信大众号:

Python技能交流合作群 ( 请勿加多个群 ):

群1: 87464755

群2: 333646237

群3: 318130924

群4: 385100854