一、 mysql 截取字符串
1. left(): 从左开始截取字符串 用法: left(str, length),
即:left(被截取字符串, 截取长度) eg: SELECT LEFT('www.csd',5) 结果为:www.c
2.right(): 从右开始截取字符串
用法: right(str, length),即:right(被截取字符串, 截取长度)
eg: SELECT RIGHT('www.csd',5) 结果为:
3.substring(): 截取特定长度的字符串
用法:substring(str, index),即:substring(被截取字符串, 从第几位开始截取);
substring(str, index, length),即:substring(被截取字符串,从第几位开始截取,截取长度);
1)从字符串的第9个字符开始读取直至结束
SELECT SUBSTRING('www.csd', 9) 结果为:com
2)从字符串的第7个字符开始,只取3个字符
SELECT SUBSTRING('www.csd', 7, 3) 结果为:n.c
3).从字符串的倒数第6个字符开始读取直至结束
SELECT SUBSTRING('www.csd', -6) 结果为:d
4).从字符串的倒数第6个字符开始读取,只取2个字符
SELECT SUBSTRING('www.csd', -6, 2) 结果为:dn
4.按关键字进行读取
用法: substring_index(str, delim, count)
即:substring_index(被截取字符串,关键字,关键字出现的次数)
1).截取第二个“.”之前的所有字符
SELECT SUBSTRING_INDEX('www.csd', '.', 2); 结果为:www.csdn
2).截取倒数第二个“.”之后的所有字符
SELECT SUBSTRING_INDEX('www.csd', '.', -2); 结果为:csd
3).如果关键字不存在,则返回整个字符串
SELECT SUBSTRING_INDEX('www.csd', 'sprite', 1); 结果为:www.csd
二、Sql Server截取字符串
1.LEN()函数: 获取字符串的长度;
eg: select len( ID_NO) as 长度 from his存在的身份证号
2.SUBSTRING()函数: 截取字符内指定位置、指定内容的字符。
SUBSTRING字符本体>, <起始位> , <结束位> )
--如果截取内容为后半部分,
--例如ABCDEF,截取C后的字符,
--起始位为4,结束位只要大于需求字符即可.
3.LEFT()函数: 截取左边第一位开始的任意数量字符。
--LEFT( <字符> ,截取数量)
4.RIGHT()函数: 截取右边第一位开始的任意数量字符。
-- RIGHT( <字符> ,截取数量)
5.CHARINDEX()函数: 返回字符串中对应字符的起始位置,从左至右。
--CHARINDEX( <查找的字符> , <字符串本体> )
6.STUFF()函数: 删除指定位置的指定长度的字符,并在删除的起点插入指定字符。
--STUFF( <字符> , 起始位, 删除位数 , <新字符> )
三、Oracle 截取字符串
1. Substr()函数:substr(string,start_pos,length)
用法:从指定位置start_pos截取字符串string的length位
2. || : 字符串连接:
select '123' || '456' from table_name
结果为:123456
3.trim 去字符串首尾空格
eg: select trim(' 123 ') from table_name
结果为:123