表值函数
2015-12-01 14:02
183 查看
最近在SQL SERVER 项目中使用了一次表值函数,做一下记录。
所谓表值函数,简单理解为返回一个table的函数。该table是一个 变量表
我们下面要实现一个功能:
传入 1,2,3,4,5 这样的字符串参数,
返回一个记录集合
函数实现如下:
对功能进行测试
并且这个函数返回的表可以和别的表进行联合查询。或者进行匹配
所谓表值函数,简单理解为返回一个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
相关文章推荐
- 近期的一点心得
- xp的虚拟机如何访问本地主机上的文件
- Android SDK组件:webview笔记
- Appcan listview 下拉刷新上啦加载源码
- 设计模式:对于一种类,有可能需要在其执行前,中,后,插入一些代码,留下接口,让调用者实现
- Android与IOS的Transform图形变换矩阵之间快速转换方法
- window.location.href无法跳转的解决办法(整理)
- iOS系统中XML&JSON解析的代码实现
- linux 基础知识总结2
- ECS Linux系统SSH服务安全配置
- linux下core文件调试方法
- 【理解】iOS获取设备信息
- android之往手机内存合sdcard卡上存储数据
- iOS 从开发到发布过程中需要注意的事项(持续补充)
- linux 基础知识总结
- 【LeetCode】70 Climbing Stairs
- Android studio 导入 PullToRefresh
- 使用android-async-http下载图片时出现org.apache.http.client.HttpResponseException: Content-Type not allowed的错误
- 折线图(七)自定义属性
- Android 开发技巧 开发常见问题归纳 需要注意的坑和解决方案