Ⅰ sql substring()从右边开始截取字符串
1、创建测试表,create table test_substr(value varchar2(200));
Ⅱ SQL截取字符串函数分享
A.截取从字符串左边开始N个字符
Declare
@S1
varchar(100)
Select
@S1='http://www.xrss.cn'
Select
Left(@S1,4)
------------------------------------
显示结果:
http
B.截取从字符串右边开始N个字符(例如取字符www.163.com)
Declare
@S1
varchar(100)
Select
@S1='http://www.163.com'
Select
right(@S1,11)
------------------------------------
显示结果:
www.163.com
C.截取字符串中任意位置及长度(例如取字符www)
Declare
@S1
varchar(100)
Select
@S1='http://www.xrss.cn'
Select
SUBSTRING(@S1,8,3)
------------------------------------
显示结果:
www
以上例子皆是已知截取位置及长度,下面介绍未知位置的例子
2.截取未知位置的函数
A.截取指定字符串后的字符串(例如截取http://后面的字符串)
方法一:
Declare
@S1
varchar(100)
Select
@S1='http://www.xrss.cn'
Select
Substring(@S1,CHARINDEX('www',@S1)+1,Len(@S1))
/*此处也可以这样写:Select
Substring(@S1,CHARINDEX('//',@S1)+2,Len(@S1))*/
------------------------------------
显示结果:
www.163.com
需要注意:CHARINDEX函数搜索字符串时,不区分大小写,因此CHARINDEX('www',@S1)也可以写成CHARINDEX('WWW',@S1)
方法二:(与方法一类似)
Declare
@S1
varchar(100)
Select
@S1='http://www.xrss.cn'
Select
Substring(@S1,PATINDEX('%www%',@S1)+1,Len(@S1))
--此处也可以这样写:Select
Substring(@S1,PATINDEX('%//%',@S1)+2,Len(@S1))
------------------------------------
显示结果:
www.163.com
函数PATINDEX与CHARINDEX区别在于:前者可以参数一些参数,增加查询的功能
方法三:
Declare
@S1
varchar(100)
Select
@S1='http://www.xrss.cn'
Select
REPLACE(@S1,'http://','')
------------------------------------
显示结果:
www.163.com
利用字符替换函数REPLACE,将除需要显示字符串外的字符替换为空
方法四:
Declare
@S1
varchar(100)
Select
@S1='http://www.xrss.cn'
Select
STUFF(@S1,CHARINDEX('http://',@S1),Len('http://'),'')
------------------------------------
显示结果:
www.163.com
函数STUFF与REPLACE区别在于:前者可以指定替换范围,而后者则是全部范围内替换
B.截取指定字符后的字符串(例如截取C:\Windows\test.txt中文件名)
与A不同的是,当搜索对象不是一个时,利用上面的方法只能搜索到第一个位置
方法一:
Declare
@S1
varchar(100)
Select
@S1='C:\Windows\test.txt'
select
right(@S1,charindex('\',REVERSE(@S1))-1)
-------------------------------------
显示结果:
text.txt
利用函数REVERSE获取需要截取的字符串长度
Ⅲ SQL 右取怎么取啊
SQL 右取用,right()函数。
right 语法
RIGHT(c,number_of_char)
返回某个被请求的文本域的右侧部分
类似的有左取,left()函数。
LEFT(c,number_of_char)
返回某个被请求的文本域的左侧部分
例:
Ⅳ 【搬运】Sql Server中截取字符串的常用方法
1、LEFT() 从左边截
语法:LEFT(character,integer) 返回 从字符串左边开始 指定个数的字符
说明:参数1:要截取的字符串,参数2:截取字符个数
示例:selectLEFT('SqlServer_2008',3)
结果:Sql
2.RIGHT() 从右边截
语法:RIGHT(character,integer) 返回 从字符串右边开始 指定个数的字符
说明:参数1:要截取的字符串,参数2:截取字符个数
示例:selectLEFT('SqlServer_2008',4)
结果:2008
3.SUBSTRING() 中间截
语法:SUBSTRING(character,start,length) 返回从字符串 中间 的字符
说明:参数1:要截取的字符串,参数2:开始截取的位数,参数3:要截取的字符长度
示例:selectSUBSTRING('SqlServer_2008',4,6)--4)
结果:Server
以上。
https://www.cnblogs.com/xielong/p/7670757.html
感谢二位!
Ⅳ SQL中,取字符串从右边第2个字符到左边的所有字符,求语句
SQL中,取字符串从右边第2个字符到左边的所有字符可以参考下面的代码:
oracle
select substr('字符串',0,Len('字符串')-2) from al;
Sql Server
select substr('字符串',0,Len('字符串')-2)
(5)sql从右边截取字符扩展阅读:
sql语句
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ (所有包含‘value1’这个模式的字符串)
排序:select * from table1 order by field1,field2 [desc]
求和:select sum(field1) as sumvalue from table1
Ⅵ mssql数据库截取字符
mssql中截取字符串可以用left,right,substring函数。
left,是从字符左边开始截取,如:截取abcdefg字符串中的前三个字符:
selectleft('abcdefg',3);
其中3为截取的长度。
rigth是从字符右边开始截取,如截取abcdefg字符串中的后三个字符:
selectright('abcdefg',3);
其中3为截取的长度。
substring,是从任意位置截取,如截取abcdefg字符串中的第二到第四个字符:
selectsubstring('abcdefg',2,3);
其中2为开始截取的位数,3为截取的长度。
Ⅶ sql字符串截取查询,该怎么解决
SQL
Server
中截取字符串常用的函数:
1.LEFT
(
character_
expression
,
integer_expression
)
函数说明:LEFT
(
'源字符串'
,
'要截取最左边的字符数'
)
返回从字符串左边开始指定个数的字符
select
LEFT('SQL_Server_2008',4
);
返回结果:SQL_
2.RIGHT
(
character_expression
,
integer_expression
)
函数说明:RIGHT
(
'源字符串'
,
'要截取最右边的字符数'
)
返回字符串中从右边开始指定个数的
integer_expression
字符
select
RIGHT('SQL_Server_2008',4
);
返回结果:2008
3.
SUBSTRING
(
character_expression
,
start
,
length
)
函数说明:SUBSTRING
(
'源字符串'
,
'截取起始位置(含该位置上的字符)'
,
'截取长度'
)
返回字符、binary、text
或
image
表达式的一部分
select
SUBSTRING('SQL_Server_2008',5
,6);
返回结果:Server