sql查询表中字段值在另一个表中的字段是否出现过

各位大神,小弟初学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