mysql的一个小问题

感谢各位大牛的的回答。我感觉之前我这个问题描述的不准确误导了大家。我的疑问并不仅仅是where not in 能解决的

比如我有一张表里fruit,里面只有一个字段name,在这里我只列出了一部分。可以认为这个表里有很多数据,不仅仅是这四个

clipboard.png

我现在有个集合,("苹果","鸭梨","西瓜","香蕉","火龙果"),我想查出这个集合中哪一个不在表中,答案是"西瓜",不知道这个sql因该怎么写

阅读 2.2k
3 个回答

一、这里如果集合是固定的,那可以先创建一个固定表如fruit1

select
    name
from fruit1
where
    not exists(
        select 1 from fruit where name=fruit1.name
    )

二、如果集合长度不确定,那就需要动态传入参数
1、先把集合转成临时表
2、通过not exists排除不在表里的行

select
    name
from
(
    select
        substring_index(substring_index('苹果,鸭梨,西瓜,香蕉,火龙果',',',help_topic_id+1),',' ,-1) as name
    from
        mysql.help_topic
    where 
        help_topic_id<5
) a
where
    not exists(
        select 1 from fruit where name=a.name
    )
select name from fruit where name not in  ("苹果","鸭梨","西瓜","香蕉","火龙果")

简单做法:select name from 新集合 where name not in (select name from fruit)

如果考虑性能问题,可使用join 表的方式,效率会高许多

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题