oracle截取字符串前几位Oracle的字符串截取方法Oracle截取字符串前几位
截取字符串是多么多么常见的一个需求啊,三家数据库厂商所实现的方法相近,但是也不相同。
首先登场的是O记的SUBSTR,在线文档地址
SUBSTR(字符串,截取起始位置,[截取长度]),例子如下:
selectsubstr('我是不是该安静的走开',9,2)strfromdual;
结果:走开
selectsubstr('我是不是该安静的走开',-2,2)strfromdual;
结果:走开
看到了吗?O记得起始位置可以是负数,也就是从右往左数第几个的意思;截取长度是可选的参数,如果不写就是代表从截取位置开始后面我全都要了,看疗效:
selectsubstr('我是不是该安静的走开',9)strfromdual;
结果:走开
selectsubstr('我是不是该安静的走开',-2)strfromdual;
结果:走开
这都是正常人的干法,可是有些考题或者人就是爱闹,起始位置总是弄得匪夷所思,比如-200,-10这些,具体情况请自己尝试。回过来再次鄙视那些人。
说完O记转Mysql,mysql的字符串截取有两个函数,substring,substr这不是一样的吗?确实也一样,因为官方文档上说substr是substring的同义词,你看多么的人性化,怎么写怎么对。官方文档地址:https://dev.mysql.com/doc/refman/5.6/en/string-functions.html#function_substr
SELECTSUBSTRING('我是不是该安静的走开'FROM9);
SELECTSUBSTRING('我是不是该安静的走开',9,2);
SELECTSUBSTRING('我是不是该安静的走开',-2);
SELECTSUBSTRING('我是不是该安静的走开',-2,2);
SELECTSUBSTRING('我是不是该安静的走开'FROM-2FOR2);
上面的结果都是走开,和O记一样一样的啊。
最后看SQLServer的,亮点是在线文档哇塞,中文的耶。
SUBSTRING(字符串或字段或某种表达式,起始位置,长度);
selectsubstring('我是不是该安静的走开',9,2);
必然的结果:走开
SS还提供了两种截取字符串的函数,left,right顾名思义,左截,右截多少个字符
selectleft('我是不是该安静的走开',2);
结果:我们
selectright('我是不是该安静的走开',2);
结果:走开
综上所述,三种数据库的截取字符串的方法相近,O记和mysql基本一致,但是要理解起始位置是"-"的含义,SS提供了三种办法。这个东西要灵活和其它函数使用,比如定位函数,和长度函数。
-
打印机已连接但无法打印打印机连接正常打印没反应的解决方法打印机已连接但是无法打印什么原因
打印机不能打印的问题,还是有挺多原因的,想知道是什么原因造成的,要逐...
-
小米手机无法启动小米手机开不了机怎么办教你一招解决小米手机开不开机怎么回事求帮助
小米用户在使用过程中,可能会遇到手机开不了机的情况。这是怎么回事呢?...
-
海信电视不识别u盘apk电视无法识别u盘apk文件终极方法海信电视不识别u盘里的apk文件
近日,有用户反映自己在安装第三方软件时遇上了问题,电视识别不了apk...
-
地铁工作人员工资是多少
地铁的一线工作人员月工资差不多能在5000以上,公积金1500-25...
-
电脑一直正在启动windows怎么办电脑开机停留在启动界面怎么办电脑启动时一直停留在"正在启动windows"界面
很多时候,我们在打开电脑时,一开机,电脑进行开机启动画面就不动了,一...
- 最近发表
- 网站分类