SQLServer拆分字符串的三种方法
来源:互联网 发布:windows命令删文件 编辑:程序博客网 时间:2024/04/28 10:06
use tempdb
go
--测试数据
declare @s varchar(1000)
set @s='ak47,mp5,1,23'
/*要求输出结果
S
----
ak47
mp5
1
23
*/
--3种方法对比:
--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)
--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
--3.[高级]XML方法:
DECLARE @idoc int;
DECLARE @doc xml;
set @doc=cast('<Root><item><S>'+replace(@s,',','</S></item><item><S>')+'</S></item></Root>' as xml)
EXEC sp_xml_preparedocument @Idoc OUTPUT, @doc
SELECT * FROM OPENXML (@Idoc, '/Root/item',2)
WITH (
[S] varchar(10)
)
- SQLServer拆分字符串的三种方法
- SQLServer拆分字符串的三种方法
- 三种方法拆分字符串
- java三种方法拆分字符串
- [转载]java三种方法拆分字符串
- SQLServer字符串批量拆分得方法
- sqlserver字符串拆分(split)方法汇总
- SQLServer字符串批量拆分得方法
- SQLServer字符串批量拆分得方法
- sqlserver字符串拆分(split)方法汇总
- sqlserver字符串拆分(split)方法汇总
- sqlserver字符串拆分(split)方法汇总
- sqlserver字符串拆分(split)方法汇总
- sqlserver字符串拆分(split)方法汇总
- sqlserver字符串拆分(split)方法汇总
- sqlserver字符串拆分(split)方法汇总
- sqlserver字符串拆分(split)方法汇总
- sqlserver字符串拆分(split)方法汇总
- t-sql数据库表的操作
- 在线翻译和人民币汇率--WebServices(免费)
- 故乡的夜
- poj 1797 dij变形
- LINUX下MP3标签编码转换
- SQLServer拆分字符串的三种方法
- 2008年10月8号
- Apache2.2和resin 3.1,windows平台单机做负载平衡
- GridView表头处理--增加图片
- 使用 Eclipse 在 Google App Engine 上创建 mashup
- 做人要低调,绝对经典的低调
- 通用数据访问层--SQLServer版
- python资源网站
- 省市县关联菜单