mysql的一个小问题
感谢各位大牛的的回答。我感觉之前我这个问题描述的不准确误导了大家。我的疑问并不仅仅是where not in 能解决的
比如我有一张表里fruit,里面只有一个字段name,在这里我只列出了一部分。可以认为这个表里有很多数据,不仅仅是这四个
我现在有个集合,("苹果","鸭梨","西瓜","香蕉","火龙果"),我想查出这个集合中哪一个不在表中,答案是"西瓜",不知道这个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