mysql的 in 用法

文章目录

    • 一、基础用法
    • [二、IN 子查询](#二、IN 子查询)
      • [IN 单列查询](#IN 单列查询)
      • [IN 多列查询](#IN 多列查询)

一、基础用法

mysql中IN常用于WHERE表达式中,其作用是查询某个范围内的数据。

(注意:null参与任何运算的布尔值都是假)

sql 复制代码
select * from where field in (value1,value2,value3,...)

当 IN 前面加上 NOT 运算符时,表示与 IN 相反的意思,即不在这些列表项内选择

sql 复制代码
select * from where field not in (value1,value2,value3,...)

二、IN 子查询

IN 单列查询

更多情况下,IN 列表项的值是不明确的,而可能是通过一个子查询得到的:

sql 复制代码
SELECT * FROM article WHERE uid IN(
	SELECT uid FROM user WHERE status=0
)

在这个 SQL 例子里,我们实现了查出所有状态为 0 的用户(可能是被禁止)的所有文章。首先通过一个查询得到所有所有 status=0 的用户:

IN 多列查询

既然能单个字段in单列结果,那么多个字段就能in多列结果了。

sql 复制代码
SELECT
	* 
FROM
	student s 
WHERE
	( s.class, s.score ) -- student表中数据符合每个班最高分的数据筛选出来
	IN (
		SELECT class, max( score )  -- 每个班级的最高分 
		FROM student 
		GROUP BY class 
	)

查询生效时间从过去到到当日最晚的数据

sql 复制代码
SELECT
    *
FROM
    template_business
WHERE
    (
        -- 生效时间是在当天
        effective_date = CURDATE()
         OR
        (
         -- 生效时间是在过去
         effective_date < CURDATE()
         AND (tmpl_biz_type, tmpl_no, effective_date)
                     IN (
                         SELECT
                             tmpl_biz_type, tmpl_no, MAX(effective_date)
                         FROM
                             template_business
                         WHERE
                             -- 生效时间是在过去
                             effective_date < CURDATE()
                         GROUP BY
                             tmpl_biz_type, tmpl_no
                         )
        )
   ) ORDER BY tmpl_biz_type, tmpl_no, effective_date DESC
相关推荐
百***992414 分钟前
MySql的慢查询(慢日志)
android·mysql·adb
q***133424 分钟前
在linux(Centos)中Mysql的端口修改保姆级教程
linux·mysql·centos
千寻技术帮2 小时前
50022_基于微信小程序同城维修系统
java·mysql·微信小程序·小程序·同城维修
q***98523 小时前
基于人脸识别和 MySQL 的考勤管理系统实现
数据库·mysql
百***25615 小时前
MySQL 实验1:Windows 环境下 MySQL5.5 安装与配置
windows·mysql·adb
转转技术团队5 小时前
分页查询的稳定性陷阱与根治方案
后端·mysql·elasticsearch
q***82916 小时前
图文详述:MySQL的下载、安装、配置、使用
android·mysql·adb
q***58197 小时前
【SQL】MySQL中的字符串处理函数:concat 函数拼接字符串,COALESCE函数处理NULL字符串
数据库·sql·mysql
懒羊羊不懒@8 小时前
【MySQL | 基础】多表查询
数据库·sql·mysql
q***0568 小时前
在Mysql环境下对数据进行增删改查
数据库·mysql