您的位置:首页 > 其它

表值函数

2015-12-01 14:02 183 查看
最近在SQL SERVER 项目中使用了一次表值函数,做一下记录。

所谓表值函数,简单理解为返回一个table的函数。该table是一个 变量表

我们下面要实现一个功能:

传入 1,2,3,4,5 这样的字符串参数,

返回一个记录集合

1

2

3

4

5 

函数实现如下:

CREATE Function Usf_SpliteString2Table (@projectids varchar(512))
RETURNS @hisProjectIDTable TABLE
(
resultRow varchar(64)
)
AS
BEGIN

DECLARE @tempsub VARCHAR(128)
DECLARE @index INT

WHILE ( Charindex(',', @projectids) > 0 )
BEGIN
SET @index = Charindex(',', @projectids)
SET @tempsub = Substring(@projectids, 0, @index)
SET @projectIDs = Substring(@projectids, @index + 1, Len(@projectids))

INSERT INTO @hisProjectIDTable
VALUES      (@tempsub)
END

IF Len(@projectids) > 0
BEGIN
INSERT INTO @hisProjectIDTable
VALUES      (@projectids)
END

RETURN

END


对功能进行测试

SELECT * from dbo.Usf_SpliteString2Table('1,2,3,4,5,6')


并且这个函数返回的表可以和别的表进行联合查询。或者进行匹配

create table testTable
(
value varchar(32)
)

insert into testTable values ('1,2')
insert into testTable values('3,4')
insert into testTable values('5,6')
insert into testTable values('1,2')
insert into testTable values('1,2')

select * from testTable a ,
dbo.Usf_SpliteString2Table('1,2,3,4,5,6') t
where charindex(t.hisprojectid,a.value) > 0
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: