流小凯 2015-07-30 10:14 采纳率: 50%
浏览 4968
已采纳

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语句应该如何写?

  • 写回答

2条回答 默认 最新

  • Evankaka 博客专家认证 2015-07-30 10:51
    关注

    先写一个分割的函数

     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,‘|’) )
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥50 adb连接不到手机是怎么回事?
  • ¥15 vs2022无法联网
  • ¥15 TCP的客户端和服务器的互联
  • ¥15 VB.NET操作免驱摄像头
  • ¥15 笔记本上移动热点开关状态查询
  • ¥85 类鸟群Boids——仿真鸟群避障的相关问题
  • ¥15 CFEDEM自带算例错误,如何解决?
  • ¥15 有没有会使用flac3d软件的家人
  • ¥20 360摄像头无法解绑使用,请教解绑当前账号绑定问题,
  • ¥15 docker实践项目