设为首页 加入收藏

TOP

crossapply和表值函数进行关联查询
2014-11-24 07:31:03 来源: 作者: 【 】 浏览:2
Tags:crossapply 函数 进行 关联 查询

目前场景是有一个兴趣爱好类型表和一个员工爱好表,员工爱好表中的爱好一列,如果这个员工有多个爱好,那么就将这些爱好放到一条记录当中,爱好之间用逗号隔开,现在需求是要将每个员工的这些爱好分隔成一条条记录查询出来,从而可以例如做员工爱好统计等应用。

爱好类型表 t_a

\

员工爱好表 t_b

\

需要的结果是

\

创建一个分隔字符串的表值函数

create function [dbo].[splitIDs](
    @Ids nvarchar(1000),
    @split_char nvarchar(10)
)
returns @t_id TABLE (id bigint)
as
begin
    declare @i int,@j int,@l int,@v bigint;
    set @i = 0;
    set @j = 0;
    set @l = len(@Ids);
    while(@j < @l)
    begin
       set @j = charindex(@split_char,@Ids,@i+1);
       if(@j = 0) set @j = @l+1;
       set @v = cast(SUBSTRING(@Ids,@i+1,@j-@i-1) as bigint);
       INSERT INTO @t_id VALUES(@v)
       set @i = @j;
    end
    return;
end

GO
采用下面的语句即可得到期望的结果
select 
    aid = t_a.id
    ,aname = t_a.name
    ,bid = t_b.id,t_b.name
from t_b
cross apply splitIDs(a_ids,',') tbl_Ids
INNER JOIN t_a ON tbl_Ids .id = t_a.id
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇服务器数据丢失的紧急处理方法 下一篇Mongo服务器集群配置学习一――主..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Libevent C++ 高并发 (2025-12-26 00:49:30)
·C++ dll 设计接口时 (2025-12-26 00:49:28)
·透彻理解 C 语言指针 (2025-12-26 00:22:52)
·C语言指针详解 (经典 (2025-12-26 00:22:49)
·C 指针 | 菜鸟教程 (2025-12-26 00:22:46)