MySQL中字符串截取主要包括三种截取方式,一是截取字符串前(后)几个字符,二是按照长度截取,三是按照分隔符截取。

一、截取方式

mysql 截取两个()中间的值 mysql截取左边两位_分隔符

二、具体方法

类型

函数名

描述

截取前(后)几个字符

left(str,n)

返回字符串 str 的前 n 个字符

right(str,n)

返回字符串 str 的后 n 个字符

按长度截取

mid(str, start, length)

从字符串 str 的 start 位置开始截取长度为 length 的子字符串

substr(str, start, length)

从字符串 str 的 start 位置开始截取长度为 length 的子字符串

substring(str, start, length)

从字符串 str 的 start 位置开始截取长度为 length 的子字符串

按分隔符截取

substring_index(str, delimiter, number)

返回从字符串 s 的第 number 个出现的分隔符 delimiter 之后的子串。

如果 number 是正数,返回第 number 个字符左边的字符串。

如果 number 是负数,返回第(number 的绝对值(从右边数))个字符右边的字符串

扩展
前往查看:MySQL 字符串函数

二、实例

select
#返回字符串 student 中的前3个字符:
	left('student',3), 												#stu
#返回字符串 student 的后两个字符:
	right('student',3),												#ent
#从字符串 'student' 中的第 2 个位置开始截取 3个 字符:
	mid('student', 2, 3), 											#tud 
	substr('student', 2, 3), 										#tud
	substring('student', 2, 3), 									#tud 
#如果 number 是正数,返回正数第 number 个分隔符左边的字符串
	substring_index('student,学生,12',',',1),			 			#student
	substring_index('student,学生,12',',',2), 						#student,学生
#如果 number 是负数,返回倒数第(绝对值number)个分隔符右边的字符串。
	substring_index('student,学生,12',',',-1),  					#12
	substring_index('student,学生,12',',',-2),  					#学生,12
	substring_index(substring_index('student,学生,12',',',-2),',',1)  #学生

#输出结果:stu|end|tud|tud|tud|student|student,学生|12|学生,12|学生