mysql-字符串类函数

【字符串类函数】

一、长度、反转、大小写转换

1.LENGTH(s)、CHAR_LENGTH(s)

# LENGTH(s)       返回字符串的字节数
SELECT LENGTH('今天')  # 6
SELECT LENGTH('today') # 5
# CHAR_LENGTH(s)  返回字符串s的字符数  等价CHARACTER_LENGTH(s)
SELECT CHAR_LENGTH('今天') # 2
SELECT CHAR_LENGTH('today') # 5

2.REVERSE(s)

# REVERSE(s)  将字符串s的顺序反过来
SELECT REVERSE('abcd') # dcba

3.LOWER(s)、UPPER(s)

# LOWER(s)  将字符串s的所有字母变成小写字母  等价LCASE(s)
SELECT LOWER('Abc') # abc
SELECT LCASE('Abc') # abc
# UPPER(s)  将字符串转换为大写   等价UCASE(s)
SELECT UPPER('abcD') # ABCD
SELECT UCASE('abcD') # ABCD

二、截取

1.LEFT(s,n)、RIGHT(s,n)、mid(s,n,len)/substring(s,n,len)/substr(s,start,length)

# LEFT(s,n)      返回字符串s的前n个字符
SELECT LEFT('today is good',5)  # today
# RIGHT(s,n)     返回字符串s的后n个字符
SELECT RIGHT('today is good',4) # good

# MID(s,n,len)  从字符串s的第n位置(从1开始)截取长度为len的子字符串,等价SUBSTRING(s,n,len)、SUBSTR(s,start,length)
SELECT MID('today-is-good',7,2) # is
SELECT SUBSTR('today-is-good',7,2) # is
SELECT SUBSTRING('today-is-good',7,2) # is

注意:非字符串类型也是可以截取的,譬如 int整数、datetime日期等。

小栗子:

# 1、截取整数
SELECT substring(1234,1,2) # 12

# 2、截取日期时间
# create_time为datetime类型的列
select create_time as 创建时间, 
       substring(create_time, 1,7) as 创建月份
from table

2. SUBSTRING_INDEX(s, delimiter, number) 

# SUBSTRING_INDEX(s, delimiter, number) 
# 返回从字符串s的第number个出现的分隔符delimiter之后的子串。
# 如果 number 是正数,返回第 number 个字符左边的字符串。
# 如果 number 是负数,返回第(number 的绝对值(从右边数))个字符右边的字符串。
SELECT SUBSTRING_INDEX('today-is-good','-',1)  # today
SELECT SUBSTRING_INDEX('today-is-good','-',-1) # good

## 正负,一方面表示从左到右/从右到左,另一方面表示取分隔符的左边值/右边值
## 超出逗号总数,则原值返回		 
SELECT SUBSTRING_INDEX('a,b,c,d',',',4) # a,b,c,d
SELECT SUBSTRING_INDEX('a',',',-1) # a

SELECT SUBSTRING_INDEX('a,b,c,d',',',1) as c1,
			 SUBSTRING_INDEX(SUBSTRING_INDEX('a,b,c,d',',',2),',',-1) as c2,
			 SUBSTRING_INDEX(SUBSTRING_INDEX('a,b,c,d',',',3),',',-1) as c3,
			 SUBSTRING_INDEX(SUBSTRING_INDEX('a,b,c,d',',',4),',',-1) as c4

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值