SQL中in和not in

SQL中in的用法

IN和NOT IN

IN 和NOT IN 都属于确定集合的一种;
IN用来查找属性值属于指定集合的元组;
NOT IN 用来查找属性值不属于指定集合的元组。

IN

例:查询计算机科学系(CS)、数学系(MA)、信息系(IS)学生的姓名和性别。

select Sname,Ssex
from Student 
Where Sdept in('CS','MA','IS');

有的题中的IN可以用多个OR来代替,比如这道题也可以写成这种形式:

select Sname,Ssex
From Student 
where Sdept='CS' or Sdept='MA' or Sdept='IS';

例 PTA-R10-42 查询图书表中书名为“C语言程序设计”和“VB程序设计”的两本书的全部信息之一

select *
from 图书
where 书名 in ('C语言程序设计','VB程序设计');
#*代表所有信息,也可一一列出
#select 条形码,书名,作者,出版社,出版日期,售价

例PTA-R10-43 在读者表查询账号D002和D003两位读者的全部信息

select *
from 读者
where 账号 in ('D002','D003');

例PTA-R10-47 在员工表中查询姓陈的男职工的全部信息

select *
from 员工
where 姓名 like "陈%" and 性别 in ('男')#也可以是:where 姓名 like "陈%" and 性别 = ('男');
#或者 having 姓名 like "陈%" and 性别 in ('男');

例PTA-R10-48 在员工表中查询陈诚瑞和钟鸣的全部信息

select *
from 员工
where 姓名 in ("陈诚瑞","钟鸣");

例PTA-R10-49 在订单表中查询011号员工和121号员工承办的订单信息

select *
from 订单
where 员工编号 in('011','121');

例PTA-R10-50 A1-2根据所在国家查找订单信息

select OrderID,CustomerID
from orders
where ShipCountry in ('Germany','Brazil','France');

NOT IN
例:查询既不是就三级科学系、数学系,也不是信息系的学生的姓名和性别。

select Sname,Ssex
from Student
where Sdept not in ('CS','MA','IS');

例:PTA-R10-51 A1-6在顾客表中找出不是特定城市的顾客信息

select CustomerID,Phone
from customers
where City not in ('Madrid','Torino','Paris');
  • 6
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值