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
相关推荐
自由会客室3 小时前
Ubuntu 24.04上安装MySQL 8.0
数据库·mysql
czhc11400756635 小时前
JAVA1026 方法;类:抽象类、抽象类继承;接口、接口继承 Linux:Mysql
java·linux·mysql
二进制_博客5 小时前
sqoop从hive导出mysql常见错误汇总
hive·mysql·sqoop
阿杰AJie6 小时前
数据库id生成方案
后端·mysql
Thepatterraining6 小时前
MySQL Java开发终极教程:三种技术栈对比,大厂资深开发经验分享
数据库·mysql
ZZZKKKRTSAE9 小时前
MySQL一篇速通
数据库·mysql·1024程序员节
是2的10次方啊10 小时前
图解MySQL索引:从二叉树到B+树的演进之路(基础篇)
mysql
蛋先生DX10 小时前
AI 友好的云开发 MySQL SDK 它来了!微信小程序能直连关系型数据库了
mysql·ai编程·小程序·云开发
IT教程资源C11 小时前
(N_156)基于springboot,vue小区物业管理系统
mysql·vue3·前后端分离·springboot小区物业