MySQL数据库-数据查询-简单查询-IN查询

使用IN查询

有的时候,当我们需要查询的目标记录限定在某个集合中的时候,在MySQL中可以使用关键字IN来实现,关键字IN可以实现判断字段的数值是否在指定集合中,该关键字的具体语法如下:

SELECT field1,field2... FROM tablename WHERE fieldm IN(value1,value2....) ;

参数field表示名称为tablename的表中的字段名,参数value表示集合中的值,通过关键字IN来判断字段fieldm的值是否在集合(value1,value2...)中,如果字段fieldm中的值在集合中,就满足和擦讯条件,该记录会被查询出来,否则不会被查询出来。

代码如下:

mysql> create table class(id int,name varchar(64));    #创建表
mysql> insert into class values(1,'Mr.Wang'),(2,'Mr.Wang'),(3,'Mr.Shi'),(4,'Mr.Li');    
#插入多列数据
mysql> select*from class where name in('Mr.Wang','Mr.Li');    #使用in查询

 创建表后插入了4条数据,设定的集合为(‘Mr.Wang','Mr.Li')只要要们插入的name有这两个值的都会被显示出来。

使用NOT IN 可以反向查询非集合的数据

语法如下:

SELECT field1,field2...

FROM tablename WHERE fieldm NOT IN(value1,value2....) ;

代码如下:

mysql> select*from class where name not in ('Mr.Wang');    #使用not in来反向查询

接上一个表,我们查询时限定了name字段只要不是Mr.Wang的都会显示。

 集合查询的注意:集合中慎用NULL

在具体使用关键字IN时,查询的集合中如果存在NULL,则不会影响查询,NULL存不存在的效果都一样。但如果使用关键字NOT IN,查询的集合中如果存在NULL,则不会查询到任何结果。

代码示例:

mysql> create table class1(id int,name varchar(64));    #创建表
mysql> insert into class1 values(1,'Mr.Wang'),(2,NULL),(3,'Mr.Shi'),(4,'Mr.Li');    #插入多列数据时插一条NULL空值
mysql> select*from class1;    #正常显示表中数据
mysql> select*from class1 where name in('Mr.Wang',NULL);    #当集合中有NULL时不会显示
mysql> select*from class1 where name in(NULL);    #光查询NULL也不会显示
mysql> select*from class1 where name not in(NULL);    #查询非空也不会显示
mysql> select*from class1 where name not in('Mr.Wang');    #同样也不会显示NULL数据

 在插入值有NULL的情况下,用in根本就查询不到,用not in也不会显示出null的那条记录。

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

长天一

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值