以下的文章主要是介绍的是SQL Server拆分字符串的3常用种方法,我前两天在相关网站看见SQL Server拆分字符串的3常用种方法的资料,觉得挺好,就拿出来供大家分享,望会给大家带来一些帮助在此方面。
- use tempdb
- use tempdb
- go
测试数据
- declare @s varchar(1000)
- set @s='ak47,mp5,1,23'
要求输出结果
- S
- ak47
- mp5
- 1
- 23
SQL Server拆分字符串的3种方法对比:
SQL Server拆分字符串1.[朴实]动态Exec方法:
- declare @s1 varchar(1000)
- set @s1=right(replace(','+@s,',',''' as S union select '''),len(replace(','+@s,',',''' as S union select '''))-12)+''''
- exec(@s1)
SQL Server拆分字符串2.[变通]表交叉方法:
- select replace(reverse((left(s,charindex(',',s)))),',','') as S from(
- select r,reverse(left(@s,r))+',' as s
- from(
- select (select count(*) from sysobjects where name<=t.name ) as r
- from sysobjects t
- )a where r<=len(@s)
- and left(@s+',',r+1) like '%,'
- )t order by r
SQL Server拆分字符串3.[高级]XML方法:
- DECLARE @idoc int;
- DECLARE @doc xml;
- set @doc=cast('
' as xml) '+replace(@s,',','')+'- EXEC sp_xml_preparedocument @Idoc OUTPUT, @doc
- SELECT * FROM OPENXML (@Idoc, '/Root/item',2)
- WITH (
- [S] varchar(10)
- )
以上的相关内容就是对SQL Server拆分字符串的三种方法的介绍,望你能有所收获。
【编辑推荐】
当前标题:SQLServer拆分字符串的3常用种方法
路径分享:http://www.mswzjz.cn/qtweb/news22/419822.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能