MySQL SUBSTRING_INDEX 函数用法

定义和用法

SUBSTRING_INDEX()函数在指定数量的分隔符出现之前返回字符串的子字符串。

语法

SUBSTRING_INDEX(string, delimiter, number)

参数值

参数

描述

string

必须项。原始字符串

delimiter

必须项。要搜索的分隔符

number

必须项。搜索分隔符的次数。可以是正数或负数。如果是正数,则此函数返回分隔符左侧的所有数字。如果是负数,则此函数返回分隔符右侧的所有内容。


在查询一个version字段的时候用到过这个函数,记录一下。比如某个version_name字段里存储的是'11.10.23.2333'的varchar类型值,想要去查询大于等于11.10.10版本的,可以用到这个函数。

SELECT * FROM table_name
WHERE 
  SUBSTRING_INDEX(version_name, '.', 1) * 10000 + 
  SUBSTRING_INDEX(SUBSTRING_INDEX(version_name, '.', 2), '.', -1) * 100 + 
  SUBSTRING_INDEX(SUBSTRING_INDEX(version_name, '.', 3), '.', -1) * 1 
  >= 111010;

解释一下:

  • 第一个SUBSTRING_INDEX(version_name, '.', 1) * 10000 是指取第一个.分隔符左边的数字,也就是11,然后乘以10000,也就变成了110000
  • 第二个SUBSTRING_INDEX(SUBSTRING_INDEX(version_name, '.', 2), '.', -1) * 100 是指首先通过SUBSTRING_INDEX(version_name, '.', 2) 取得第二个.分隔符左侧的,也就是11.10,然后再通过SUBSTRING_INDEX('11.10','.',-1) 取第一个.分隔符右侧的,也就是10,最后乘以100加到前面那个数字上。此时也就是110000+10*100 = 111000
  • 第三个SUBSTRING_INDEX(SUBSTRING_INDEX(version_name, '.', 3), '.', -1) * 1 是指首先通过SUBSTRING_INDEX(version_name, '.', 3) 取得第三个.分隔符左侧的,也就是11.10.23,然后再通过SUBSTRING_INDEX('11.10.23','.',-1) 取最后一个.分隔符右侧的,也就是23,最后乘以1加到前面那个数字上。此时也就是111000+23=111023



 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值