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

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,‘|’) )
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • threenewbee 2015-07-30 10:22
    关注

    最好不要把数据用 | 分割存入数据表,查询效率低也不方便

    http://www.cnblogs.com/aierong/archive/2008/11/19/sqlserver_split.html

    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 求苹果推信imessage批量推信技术
  • ¥15 ubuntu 22.04 系统盘空间不足。隐藏的docker空间占用?(相关搜索:移动硬盘|管理系统)
  • ¥15 利用加权最小二乘法求亚马逊各类商品的价格指标?怎么求?
  • ¥15 c++ word自动化,为什么可用接口是空的?
  • ¥15 Matlab计算100000*100000的矩阵运算问题:
  • ¥50 VB6.0如何识别粘连的不规则的数字图片验证码
  • ¥16 需要完整的这份订单所有的代码,可以加钱
  • ¥15 Stata数据分析请教
  • ¥15 请教如何为VS2022搭建 Debug|win32的openCV环境?
  • ¥15 关于#c++#的问题:c++如何使用websocketpp实现websocket接口调用,求示例代码和相关资料