SQL2000/2005字符串拆分为列表通用函数
来源:互联网 发布:怎么租淘宝店 编辑:程序博客网 时间:2024/05/17 04:45
--------------------------------------------------------------------------
--SQL2000/2005字符串拆分为列表通用函数
IF OBJECT_ID('f_getstr') IS NOT NULL
DROP FUNCTION f_getstr
GO
CREATE FUNCTION f_getstr(
@s NVARCHAR(4000), --待分拆的字符串
@flag NVARCHAR(10)='' --数据分隔符
)RETURNS @r TABLE(col NVARCHAR(1000))
AS
BEGIN
IF ISNULL(@flag,'')='' AND LEN(ISNULL(@flag,'')+'a')=1
INSERT @r
SELECT SUBSTRING(@s,number+1,1)
FROM master..spt_values
WHERE TYPE='p' and number<LEN(@s+'a')-1
ELSE
INSERT @r
SELECT SUBSTRING(@s,number,CHARINDEX(@flag,@s+@flag,number)-number)
FROM master..spt_values
WHERE TYPE='p' and number<=len(@s+'a')
--AND SUBSTRING(@flag+@s,number,1)=@flag --用此条件或下面的条件均可
AND CHARINDEX(@flag,@flag+@s,number)=number
RETURN
END
GO
--本实例技巧,利用master库自带的spt_values表,取number字段作为连续的序号,
--省去创建序号表,尽量做到通用,再加上字符串处理函数取得最终结果。
--1.每个字符拆分取出
SELECT * FROM dbo.f_getstr(N'一个世界一个家',NULL)
SELECT * FROM dbo.f_getstr(N'一个世界一个家','')
SELECT * FROM dbo.f_getstr(N'一个世界一个家',default)
/*
col
-------
一
个
世
界
一
个
家
(7 行受影响)
*/
--2.指定分隔符拆分取出
SELECT * FROM dbo.f_getstr(N'一个 世界 一个 家',N' ')
SELECT * FROM dbo.f_getstr(N'一个,世界,一个,家',N',')
SELECT * FROM dbo.f_getstr(N'一个%世界%一个%家',N'%')
SELECT * FROM dbo.f_getstr(N'一个中国世界中国一个中国家',N'中国')
/*
col
---------
一个
世界
一个
家
(4 行受影响)
*/
--3.SQL2005以上版本可以结合apply进行拆分列值
IF OBJECT_ID('tb') IS NOT NULL
DROP TABLE tb
GO
CREATE TABLE tb (id INT,col VARCHAR(30))
INSERT INTO tb VALUES(1,'aa,bb')
INSERT INTO tb VALUES(2,'aaa,bbb,ccc')
GO
SELECT id,b.col FROM tb CROSS APPLY f_getstr(col,',') b
SELECT id,b.col FROM tb OUTER APPLY f_getstr(col,',') b
/*
id col
----------- -----------
1 aa
1 bb
2 aaa
2 bbb
2 ccc
(5 行受影响)
*/
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/htl258/archive/2010/04/28/5537235.aspx
- SQL2000/2005字符串拆分为列表通用函数
- SQL2000/2005字符串拆分为列表通用函数
- SQL2000/2005字符串拆分为列表通用函数
- SQL2000/2005字符串拆分为列表通用函数
- SQL2000/2005字符串拆分为列表通用函数
- SQL2000/2005字符串拆分为列表通用函数
- SQL2000/2005字符串拆分为列表通用函数
- SQL2000/2005字符串拆分为列表通用函数
- SQL2000/2005字符串拆分为列表通用函数
- 【叶子函数分享三十六】SQL2000/2005字符串拆分为列表通用函数
- 【叶子函数分享三十六】SQL2000/2005字符串拆分为列表通用函数
- 字符串拆分函数 sql2000
- SQL2000环境中拆分字符串呈列值显示
- Python split() 函数 拆分字符串 将字符串转化为列
- Python split() 函数 拆分字符串 将字符串转化为列
- Python split() 函数 拆分字符串 将字符串转化为列
- oracle 拆分字符串函数
- 各种字符串拆分函数
- VC实现线程池
- C# 修改IIS相关设置代码
- c# 事件,vs2010的样例
- volatile
- C#判断字符串中是否有中文
- SQL2000/2005字符串拆分为列表通用函数
- 免安装版的Tomcat设置开机自启动
- 84827046
- 调试
- Linux内核源码阅读之内存映射篇
- 学习型组织的特点
- texlive2009 的安装
- 常量指针与指向常量的指针
- Linux内核源码阅读之打开文件篇