mysql 截取指定位置后面的所有的字符
也就是得到555。但然下划线后面的内容长度是不定的。
不好意思,还有啊。怎么截取G和_ 之间的内容呢?此例是 3. 展开
mysql 截取指定位置后面的所有的字符可以使用命令:
SELECT SUBSTRING_INDEX( 'G3_555') , '_' , -1) AS str_1 FROM tablename;
其中SUBSTRING_INDEX是截取字符串的函数。
'G3_555' , '_' , -1分别表示从第一个_符号开始截取_右边的字符串。
扩展资料
mysql sql语句中SUBSTRING_INDEX的用法介绍:
SUBSTRING_INDEX(s, delimiter, number) 返回从字符串 s 的第 number 个出现的分隔符 delimiter 之后的子串。
如果 number 是正数,返回第 number 个字符左边的字符串。
如果 number 是负数,返回第(number 的绝对值(从右边数))个字符右边的字符串。
例如:
SELECT SUBSTRING_INDEX('a*b','*',1)
返回:a
SELECT SUBSTRING_INDEX('a*b','*',-1)
返回:b
SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('a*b*c*d*e','*',3),'*',-1)
返回:c
-1表示则是从后倒数出现1次'_' ,到字符串结束。
select substring(截取的列名, 2,INSTR(截取的列名, '_')-2) from 表名; //截取G和_ 之间的内容
// substring(被截取字段,从第几位开始截取,截取长度)
昨晚来不及做出来,今天补上
-> SUBSTRING('G3_555', INSTR('G3_555', '_') + 1);
+------------------------------------------------+
| SUBSTRING('G3_555', INSTR('G3_555', '_') + 1) |
+------------------------------------------------+
| 555 |
+------------------------------------------------+
1 row in set (0.00 sec)