各位大神,小弟初学sql想请教一个问题~~先谢谢大家啦~~
例如我有两个表:
表A:personal (人员表)
pid name
1 aaa
2 bbb
3 ccc
4 ddd
5 eee
6 ffff
7 ggg
表B:metting (会议表,pidlist代表参加会议的人员,用“|”分隔)
mid pidlist
1 |2|3|4|
2 |1|3|4|
3 |1|2|4|
我想要 列出表A中没有参加会议的人,如果按我的要求,以上数据得到的结果数据集应该是:
pid
5
6
7
请问各位大神sql语句应该如何写?
先写一个分割的函数
create function f_split(@c varchar(2000),@split varchar(2))
returns @t table(col varchar(20))
as
begin
while(charindex(@split,@c)<>0)
begin
insert @t(col) values (substring(@c,1,charindex(@split,@c)-1))
set @c = stuff(@c,1,charindex(@split,@c),'')
end
insert @t(col) values (@c)
return
end
然后调用
select * from personal where pid not in(dbo.f_split (select pidlist from mid,‘|’) )
最好不要把数据用 | 分割存入数据表,查询效率低也不方便
http://www.cnblogs.com/aierong/archive/2008/11/19/sqlserver_split.html