mysql的一个小问题

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

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

mysql的一个小问题

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


回答:

一、这里如果集合是固定的,那可以先创建一个固定表如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 表的方式,效率会高许多

以上是 mysql的一个小问题 的全部内容, 来源链接: utcz.com/p/937618.html

回到顶部