SQL 截取函数

目录

1、substring

2、left

3、right

4、substring_index


1、substring

用途:字段截取从指定开始的字符开始,截取要的数;指定开始的字符数字可以用负的,指定开始的字符从后往前(向左)数,截取要的数不能为负。

语法格式:substring(field,n,m)

中文注释:substring(字段,从第n位开始,从n开始截取m位)

用法:

sql 复制代码
#从第1位开始截取,往后(向右)截取5位
SELECT SUBSTRING('12345678', 1, 5) AS A from dual;
#输出 '12345'

#从第2位开始截取,往后(向右)截取5位
SELECT SUBSTRING('12345678', 1, 5) AS A from dual;
#输出 '23456'
sql 复制代码
#-2是从倒数第2位开始,往后(向右)截取5位,后面不够5位,有多少就截多少
SELECT SUBSTRING('12345678', -2, 5) AS A from dual;
#输出 '78'

#-4是从倒数第1位开始,往后(向右)截取3位,后面不够5位,有多少就截多少
SELECT SUBSTRING('12345678', -4, 3) AS A from dual;
#输出 '567'

2、left

用途:从字段左边开始截取向后(向右)指定数的字符。

语法格式:left(field,n)

中文注释:left(字段,从左开始截取到第n位)

用法:

sql 复制代码
#从左开始,截取2位
SELECT LEFT('12345678',2) A FROM dual
#输出'12'


#从左开始,截取4位
SELECT LEFT('12345678',4) A FROM dual
#输出'1234'

3、right

用途:从字段右边开始截取向前(向左)指定数的字符。

语法格式:left(feld,n)

中文注释:left(字段,从右边开始截取到第n位)

用法:

sql 复制代码
#从右开始,向前(向左)截取3位
SELECT right('12345678', 3) AS A from dual;
#输出'678'

#从右开始,向前(向左)截取5位
SELECT right('12345678', 5) AS A from dual;
#输出'45678'

4、substring_index

用途:从指定分隔符出现的次数,开始截取向后(向右)所有的字符;负数就向前(向左)截取所有的字符。

语法格式:substring_index(feld,str,count)

中文注释:substring_index(字段,指定分隔符,截取指定分隔符出现第count次之后的所有字符)

用法:

sql 复制代码
#从左往右数指定分隔符 . 出现1次的地方,开始截取向后(向左)所有字符
SELECT substring_index('12345678.sd111.sa.51wf','.',1) AS A from dual;
#输出'12345678'

#从左往右数指定分隔符 . 出现3次的地方,开始截取向后(向左)所有字符
SELECT substring_index('12345678.sd111.sa.51wf','.',3) AS A from dual;
#输出'12345678.sd111.sa'
sql 复制代码
#从右往左数指定分隔符 . 出现1次的地方,开始截取向后(向左)所有字符
SELECT substring_index('12345678.sd111.sa.51wf','.',-1) AS A from dual;
#输出'51wf'

#从右往左数指定分隔符 . 出现3次的地方,开始截取向后(向左)所有字符
SELECT substring_index('12345678.sd111.sa.51wf','.',-3) AS A from dual;
#输出'sd111.sa.51wf'
相关推荐
iAm_Ike3 小时前
Go 中自定义类型与基础类型间的显式类型转换详解
jvm·数据库·python
iuvtsrt3 小时前
Golang怎么实现方法集与接口的匹配_Golang如何理解值类型和指针类型实现接口的区别【详解】
jvm·数据库·python
DianSan_ERP4 小时前
如何通过抖店订单接口实现订单状态管理与履约自动化?
运维·自动化
b***25114 小时前
18650电池点焊机:电阻焊技术如何决定电池组的成败|深圳比斯特自动化
运维·自动化
tongluowan0074 小时前
MySQL中列数量及长度
数据库·mysql
原来是猿4 小时前
网络计算器:理解序列化与反序列化(中)
linux·运维·服务器·网络·tcp/ip
前端老曹4 小时前
Docker 从入门到放弃:完整指南
运维·docker·容器
-liming-5 小时前
单片机设计_串口调试工具
数据库·单片机·mongodb
鹿角片ljp5 小时前
从告警检测到智能研判:SQL 注入研判模型的设计与实践
数据库·sql
AOwhisky5 小时前
虚拟化技术学习笔记
linux·运维·笔记·学习·虚拟化技术