SQL2000/2005字符串拆分为列表通用函数
来源:互联网 发布:修改无线网卡mac地址 编辑:程序博客网 时间:2024/05/16 15:53
--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 行受影响)
*/
source: 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 拆分字符串函数
- 各种字符串拆分函数
- SQL2008 Merge关键字用法与简例
- 水瓶座
- tomcat 403错误简单解决方法
- 用oracle調用java來創建文件夾
- 快速得到数据库中所有用户表的记录数(行数)
- SQL2000/2005字符串拆分为列表通用函数
- C语言常见命名规范
- struct和typedef struct
- 从今天开始复习Hibernate
- 谁有java方面的中英文对照的技术介绍,毕设用,急用。。。
- 如何将对象读写到 XML 中
- SimpleDateFormat must be synchronized by yourself.
- 我的积分呢
- C++中的几个关键字:static,const,inline