html截取字符串_Oracle,Mysql,SQL Server三种数据库的字符串截取方法SUBSTR「ING」

982015f43d400cafa386c1c036898bbe.png

截取字符串是多么多么常见的一个需求啊,三家数据库厂商所实现的方法相近,但是也不相同。

首先登场的是O记的SUBSTR,在线文档地址:https://docs.oracle.com/cd/E11882_01/server.112/e41084/functions181.htm#SQLRF06114

SUBSTR(字符串,截取起始位置,[截取长度]),例子如下:

select substr('我是不是该安静的走开',9,2) str from dual;

结果:走开

select substr('我是不是该安静的走开',-2,2) str from dual;

结果:走开

看到了吗?O记得起始位置可以是负数,也就是从右往左数第几个的意思;截取长度是可选的参数,如果不写就是代表从截取位置开始后面我全都要了,看疗效:

select substr('我是不是该安静的走开',9) str from dual;

结果:走开

select substr('我是不是该安静的走开',-2) str from dual;

结果:走开

这都是正常人的干法,可是有些考题或者人就是爱闹,起始位置总是弄得匪夷所思,比如-200,-10这些,具体情况请自己尝试。回过来再次鄙视那些人。

说完O记转Mysql,mysql的字符串截取有两个函数,substring,substr这不是一样的吗?确实也一样,因为官方文档上说substr是substring的同义词,你看多么的人性化,怎么写怎么对。官方文档地址:https://dev.mysql.com/doc/refman/5.6/en/string-functions.html#function_substr

SELECT SUBSTRING('我是不是该安静的走开' FROM 9);

SELECT SUBSTRING('我是不是该安静的走开',9,2);

SELECT SUBSTRING('我是不是该安静的走开', -2);

SELECT SUBSTRING('我是不是该安静的走开', -2, 2);

SELECT SUBSTRING('我是不是该安静的走开' FROM -2 FOR 2);

上面的结果都是走开,和O记一样一样的啊。

最后看SQL Server的,亮点是在线文档 哇塞,中文的耶。

SUBSTRING ( 字符串或字段或某种表达式 ,起始位置,长度);

select substring('我是不是该安静的走开',9,2);

必然的结果:走开

SS还提供了两种截取字符串的函数,left,right顾名思义,左截,右截多少个字符

select left('我是不是该安静的走开',2);

结果:我们

select right('我是不是该安静的走开',2);

结果:走开

综上所述,三种数据库的截取字符串的方法相近,O记和mysql基本一致,但是要理解起始位置是"-"的含义,SS提供了三种办法。这个东西要灵活和其它函数使用,比如定位函数,和长度函数。这个案例要不要在这讲里弄呢?算了下期吧!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值