mysql的substring_index

语法说明

  1. 语法:
substring_index(str,sep,num)。
substring_index(需要处理的字符串,分隔符,序号)
  • 序号必须非0整数。
  • 为正表示从字符串正向截取,截取分隔符出现第num次之前的字符串。
  • 为负,表示从字符串末尾截取。截取字符串出现第num次之后的字符串。
  • substring_index可以嵌套使用,重复截取,直到截取到想要的数据。
  1. demo
- 从头开始截取,直到截取到第一次分隔符出现的位置(不包含分隔符)。
SELECT SUBSTRING_INDEX("www.baidu.com www.qq.com www.sina.com www.google.com",".",1);
运行结果:www

- 从末尾开始向前截取,直到截取到第一次分隔符出现的位置(不包含分隔符)。
SELECT SUBSTRING_INDEX("www.baidu.com www.qq.com www.sina.com www.google.com",".",-1);
运行结果:com

-从末尾向前截取,截取到,第3次分隔符出现的位置(不包含分隔符)。
SELECT SUBSTRING_INDEX("www.baidu.com www.qq.com www.sina.com www.google.com",".",-3);
运行结果:com www.google.com

-从头开始截取,直到截取到第3次分隔符出现的位置(不包含分隔符)。
SELECT SUBSTRING_INDEX("www.baidu.com www.qq.com www.sina.com www.google.com",".",3);
运行结果:www.baidu.com www

-从前开始,截取到第3个www出现的位置(不包含www)
SELECT SUBSTRING_INDEX("www.baidu.com www.qq.com www.sina.com www.google.com","www",3);
运行结果:www.baidu.com www.qq.com 

-SUBSTRING_INDEX可以嵌套使用,实现复杂的截取功能
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX("www.baidu.com www.qq.com www.sina.com www.google.com","www.",-2),".",1);
运行结果:sina   ①.第一次截取结果为sina.com www.google.com ②.2次截取第一个.,所以为sina。

  1. 思考
- 如何截取掉开头不要的部分:例如 qqwww.baidu.com.qq,如何截取到www.baidu.com.qq
  SELECT SUBSTRING_INDEX("qqwww.baidu.com.qq","qq",-2);
  运行结果:www.baidu.com.qq
- 上述场景是qq次数确定时。但如果出现多个qq(qqwww.baiduqq.comqq.qq)呢,此时,上述截取就报错。有没比较兼容的写法。
   SELECT SUBSTRING_INDEX("qqwww.baiduqq.comqq.qq","qq",-2); 
   执行结果.qq  ERROR 
   SELECT SUBSTRING("qqwww.baiduqq.comqq.qq",LOCATE("qq","qqwww.baiduqq.comqq.qq")+LENGTH('qq'));

- 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL SUBSTRING_INDEX() 函数用于返回一个字符串中指定分隔符出现的次数之前或之后的所有字符。该函数可以接受三个参数:待分割的字符串、分隔符以及分隔符出现的次数。使用该函数可以方便地从一个字符串中提取指定分隔符出现次数之前或之后的子串。例如,可以使用该函数从一个 URL 中提取出域名部分。函数语法如下: ``` SUBSTRING_INDEX(str, delim, count) ``` 其中,str 表示待分割的字符串;delim 表示分隔符;count 表示分隔符出现的次数。如果 count 为正数,则返回分隔符出现次数之前的子串;如果 count 为负数,则返回分隔符出现次数之后的子串。如果分隔符在字符串中不存在,则函数返回整个字符串。 ### 回答2: MySQLSUBSTRING_INDEX函数用于从一个字符串中获取指定分隔符之前或之后的子串。 SUBSTRING_INDEX函数有三个参数:源字符串、分隔符和计数器。 源字符串是需要处理的字符串,可以是一个列名、一个变量或一个字符串常量。 分隔符是指定的分隔符。当计数器为正数时,函数将返回分隔符之前的部分;当计数器为负数时,函数将返回分隔符之后的部分。 计数器可以是一个整数或一个表达式。它指定要返回的子串在源字符串中的位置。当计数器为正数时,函数从源字符串的起始位置开始搜索;当计数器为负数时,函数从源字符串的末尾开始搜索。计数器的绝对值确定要返回的子串的数量。 下面是一些示例用法: 1. 返回源字符串中第一个分隔符之前的子串: SELECT SUBSTRING_INDEX('www.example.com', '.', 1); // 返回"www" 2. 返回源字符串中最后一个分隔符之后的子串: SELECT SUBSTRING_INDEX('www.example.com', '.', -1); // 返回"com" 3. 返回源字符串中前两个分隔符之前的子串: SELECT SUBSTRING_INDEX('www.example.com', '.', 2); // 返回"www.example" SUBSTRING_INDEX函数非常有用,特别是在处理需要从字符串中提取特定部分的情况下。它可以用于解析URL、文件路径、电子邮件地址等,提取所需的信息。 ### 回答3: MySQL中的SUBSTRING_INDEX函数用于从一个字符串中获取子字符串,根据指定的分隔符进行切割。 SUBSTRING_INDEX函数的语法如下: SUBSTRING_INDEX(str, delim, count) 其中,str是要切割的字符串;delim是用于切割的分隔符;count是指定切割后的部分,如果为正数,则表示从左往右切割;如果为负数,则表示从右往左切割。 举个例子来说明SUBSTRING_INDEX函数的使用。假设我们有一个字符串"apple,bed,cat,dog",我们想要从该字符串中获取逗号前的部分。 使用SUBSTRING_INDEX函数的实例如下: SELECT SUBSTRING_INDEX('apple,bed,cat,dog', ',', 1) AS result; 运行上述语句后,将得到"apple"作为结果,因为逗号为分隔符,并且指定了count为1,表示获取第一个逗号前的部分。 如果希望从右往左获取子字符串,可以将count参数设置为负数,例如: SELECT SUBSTRING_INDEX('apple,bed,cat,dog', ',', -1) AS result; 运行上述语句后,将得到"dog"作为结果,因为逗号为分隔符,并且指定了count为-1,表示获取最后一个逗号后的部分。 SUBSTRING_INDEX函数在MySQL中非常有用,可以方便地从字符串中提取需要的部分。无论是从左往右还是从右往左,都可以根据给定的分隔符和count参数进行准确的切割。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值