㈠ sql截取字符串
selectWBOOK_NO=
casewhenWBOOK_NOlike'%H%'andWBOOK_NOnotlike'%HW%'thenSUBSTRING(WBOOK_NO,7,9)
whenWBOOK_NOlike'H%'andthenSUBSTRING(WBOOK_NO,8,9)end,
WBOOK_NO
fromEMS_PDE_HEADWHEREWBOOK_NO='H3001720130823003698'ORWBOOK_NO='HW300172012048035872'
LIKE 'H%'时再and NOT LIKE 'HW%'就好啦
㈡ sql截取字符串!
declare
@s
nvarchar(200),@s0
nvarchar(20),@s1
nvarchar(200),@s2
nvarchar(200)
set
@s0='默认风格'
set
@s='默认风格|#007168|23|紫色风格|#E8D6FE|21|蓝色风格|#bad2fe|22'
declare
@r1
int,@r2
int
if
substring(@s,len(@s),1)<>'|'
set
@s=@s+'|'
set
@r1=charindex(@s0,@s)
--文字开始位置
select
@s1=substring(@s,@r1+len(@s0)+1,len(@s))
--文字+“|”以后的子串
set
@r2=@r1+charindex('|',@s1)+len(@s0)
--子串中第一个“|”相对于原串的起始位置
set
@s2=substring(@s1,charindex('|',@s1)+1,len(@s1))
--第一个“|”后的子串
set
@r2=@r2+charindex('|',@s2)
print
substring(@s,1,@r1-1)+substring(@s,@r2+1,len(@s))
你可以把@s0改成任意的什么“风格”。
把这段代码修改一下,可以作成一个函数,把@s0和@s作为参数,最后的print作为返回值。
㈢ 简单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 截取字符串
简单的:
select substr(‘04.06.02.063-48-Z952’,1,instr(‘04.06.02.063-48-Z952’,'-',1,2)-1) from al ;
instr(04.06.02.063-48-Z952,'-',1,2)的意思是找到第二个出现的-号,然后减去1,把左边都截取下来就ok了。
实际使用的时候,用字段名替换那个字符串就ok了。
希望帮到你,请采纳最佳。
㈤ 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截取字符串语句
啥意思?截取最后一个下划线后边的所有内容呗?
啥数据库啊?
㈦ SQL中求截取字符串语句
可以通过substring方法实现。
sql: select substring('123456789',5,2) from al;
解释:第一个参数表示要截取的字符串,第二个参数是起始位置,第三个参数是,截取的长度。
执行结果:56。
㈧ 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截取字段字符串
declare@svarchar(100),@sqlvarchar(1000)
set@s='中国-浙江省-宁波市-海曙区'
set@sql='selectcol='''+replace(@s,'-','''unionallselect''')+''''
PRINT@sql
exec(@sql)