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 SERVER 字符串截取
1.将字符串中从某个字符开始截取一段字符,替换成另一字符
select stuff('helloworld!',4,4,'****')
hel****rld!
2.指定字符串起始位置,截取指定长度
select substring('helloworld!',4,5)
lowor
3.替换指定字符串
select replace('helloworld!','ld','aa')
helloworaa!
4.去除字符串两端空格
select ltrim(' helloworld!')
helloworld!
5.用0替换NULL【isnull( )】
select ISNULL(KCRKD2_SCDDLS,0) from KCRKD2
返回0
6.取字符串,再转化为整数
select convert(float,substring(xsddmx_wlbh,6,3)) from XSDDMX
7.字符串前三个是固定的,后面长度是变化的用LEN()取字符串长度,去掉前三个字符(截取右端固定字符数换成LEFT)
SELECT RIGHT(KCRKD3_JH,LEN(KCRKD3_JH)-3) FROM KCRKD3
返回B160459B01487
8.从‘-’向后截取8位字符(charindex()返回字符位置)
select SUBSTRING('E03AHJC-E1701005020184',charindex('-','E03AHJC-E1701005020184')+1,8)
9. replace将‘h’替换
SELECT REPLACE('Hello,World!','h','2') 2ello,World!
SELECT REPLACE('Hello,World!','h','') ello,World!
SELECT REPLACE('Hello,World!',' ','2') Hello,World!
10.复制字符
select REPLICATE('Hello,World!',3)
时间函数
1.截取两个时间的时间差
select DATEDIFF(D,TMBASE_DATE,GETDATE()) from TMBASE
Ⅲ 如何从多个位置截取字符串的SQL语句
SQL 中从多个位置截取字符串,需要配合left,right,rtrim三个函数来实现。
一、函数语法:
1、left()
LEFT (<character_expression>, <integer_expression>)
返回character_expression 左起 integer_expression 个字符。
2、RIGHT()
RIGHT (<character_expression>, <integer_expression>)
返回character_expression 右起 integer_expression 个字符。
3、LTRIM(character_expression) 把字符串character_expression头部的空格去掉。
4、RTRIM(character_expression) 把字符串character_expression尾部的空格去掉。
二、代码实例:
图中以:表a,ID为2,C列的值“12345678”为例:
其中最后一句中的right(rtrim(c),1),是因为字符只有8位,在right函数中,系统自动按C列定义的长度使用空格补足。也就是说如果是right(c,1)返回空字符“”,所以使用rtrim(c)把右边空格删除。
Ⅳ 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
Ⅳ 简单SQL语句,如何截取指定分隔符前字符串
一、用到的函数:substring(' ', , )、charindex(' ',' ')
select SUBSTRING('[email protected]',1,charindex('@','[email protected]')-1)
1.substring(字符串表达式,开始位置,长度):
从一个指定字符串的指定位置截取制定长度的字符;
第一个参数表示被截取的字符串;
第二个参数表示要在第一个参数中开始截取的位置;
第三个参数表示要截取的长度。
例如:select substring('abc123',1,2) →返回ab
从字符串‘abc123’的第一个字符开始截取,共截取两个字符,最后得到‘ab’。
2.charindex(字符串表达式1,字符串表达式2[,整数表达式]):
在字符串2中查找字符串1,如果存在返回第一个匹配的位置,如果不存在返回0。如果字符串1和字符串2中有一个是null则返回null。
可以指定在字符串2中查找的起始位置。
例如:select charindex('ab','BCabTabD') → 返回3
select charindex('ab','BCabTabD',4) →返回6
二、用到的函数:left(' ', )、charindex(' ',' ')
select LEFT('[email protected]',charindex('@','[email protected]')-1)
1.left(字符串表达式,整数表达式):
从字符串表达式的最左边开始截取整数表达式个字符。
例如:select left('abcdef',3) →返回abc
Ⅵ sql数据库截取字符串函数
Oracle中 其语法为:
substr函数的用法,取得字符串中指定起始位置和长度的字符串 ,默认是从起始位置到结束的子串。
substr( string, start_position, [ length ] ) substr('目标字符串',开始位置,长度)
如:
substr('This is a test', 6, 2) would return 'is'
substr('This is a test', 6) would return 'is a test'
substr('TechOnTheNet', -3, 3) would return 'Net'
substr('TechOnTheNet', -6, 3) would return 'The'select substr('Thisisatest', -4, 2) value from al
Ⅶ sql截取字符串函数
Sql Server:
selectsubstring(name1,0,charindex('.',name1))fromtable1
Oracle:
selectsubstr(name1,0,instr(name1,'.'))fromtable1
以上两种数据库的,希望可以帮到你
Ⅷ sql中怎样把字符串截取为字段
sql语句可以截取指定字段后面的字符串,以sqlserver为例,需要用到charindex函数和substring函数。
如test表中有如下数据,要求截图str字段中逗号后边的内容。
可用如下语句:
1
select id,substring(str,charindex(',',str)+1,len(str)-charindex(',',str)) from test;
结果截图:
charindex函数说明:
语法:
CHARINDEX ( expression1 , expression2 , [ start_location ] )
参数:
expression1
一个表达式,其中包含要寻找的字符的次序。expression1 是一个短字符数据类型分类的表达式。
expression2
一个表达式,通常是一个用于搜索指定序列的列。expression2 属于字符串数据类型分类。
start_location
在 expression2 中搜索 expression1 时的起始字符位置。如果没有给定 start_location,而是一个负数或零,则将从 expression2 的起始位置开始搜索。
substring函数说明:
语法:
substring( expression, start, length)
参数:expression 字符串、二进制字符串、文本、图像、列或包含列的表达式start 整数或可以隐式转换为 int 的表达式,指定子字符串的开始位置length 整数或可以隐式转换为 int 的表达式,指定子字符串的长度
Ⅸ sql中where截取字符串字符
不管哪个库,sql中一般都支持substring 或者它的变种 substr left right mid等