首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql的not in用法

基础概念

NOT IN 是 MySQL 中的一个子查询操作符,用于筛选出不在某个子查询结果集中的记录。它通常用于排除某些特定的值。

语法

代码语言:txt
复制
SELECT column_name(s)
FROM table_name
WHERE column_name NOT IN (subquery);

优势

  1. 简洁性NOT IN 可以用一行 SQL 语句完成复杂的排除操作。
  2. 灵活性:可以与其他 SQL 函数和操作符结合使用,实现更复杂的数据筛选。

类型

NOT IN 主要用于以下几种类型:

  1. 排除特定值:例如,排除某个表中的特定记录。
  2. 排除子查询结果:例如,排除另一个表中的某些记录。

应用场景

假设我们有两个表 employeesdepartments,我们想要找出所有没有分配部门的员工。

代码语言:txt
复制
SELECT *
FROM employees
WHERE department_id NOT IN (SELECT department_id FROM departments);

常见问题及解决方法

问题:NOT IN 子查询返回空结果集

原因:如果子查询返回空结果集,NOT IN 将返回所有记录。这可能不是预期的结果。

解决方法:使用 NOT EXISTS 替代 NOT IN,因为 NOT EXISTS 在子查询返回空结果集时不会返回所有记录。

代码语言:txt
复制
SELECT *
FROM employees e
WHERE NOT EXISTS (SELECT 1 FROM departments d WHERE d.department_id = e.department_id);

问题:性能问题

原因:当子查询返回大量数据时,NOT IN 可能会导致性能问题。

解决方法:优化子查询,确保其返回的数据量尽可能小。可以考虑使用索引、分区等技术来提高查询性能。

示例代码

假设有两个表 usersorders,我们想要找出所有没有订单的用户。

代码语言:txt
复制
-- 创建示例表
CREATE TABLE users (
    user_id INT PRIMARY KEY,
    username VARCHAR(50)
);

CREATE TABLE orders (
    order_id INT PRIMARY KEY,
    user_id INT,
    order_date DATE
);

-- 插入示例数据
INSERT INTO users (user_id, username) VALUES (1, 'Alice'), (2, 'Bob'), (3, 'Charlie');
INSERT INTO orders (order_id, user_id, order_date) VALUES (1, 1, '2023-01-01'), (2, 2, '2023-01-02');

-- 查询没有订单的用户
SELECT *
FROM users
WHERE user_id NOT IN (SELECT user_id FROM orders);

参考链接

希望这些信息对你有所帮助!如果有更多问题,请随时提问。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQLJOIN用法

数据库中JOIN称为连接,连接主要作用是根据两个或多个表中列之间关系,获取存在于不同表中数据。连接分为三类:内连接、外连接、全连接。...另外还有CROSS JOIN(笛卡尔积),个人认为如果要理解MySQL中JOIN各种连接,只需要理解笛卡尔积就足够了。...笛卡儿积 笛卡尔乘积是指在数学中,两个集合X和Y笛卡尓积(Cartesian product),又称直积,表示为X × Y,第一个对象是X成员而第二个对象是Y所有可能有序对其中一个成员。...下图解释了表t1和t2之间内连接操作: ? 内连接 LEFT JOIN 左连接(LEFT JOIN)含义就是求两个表交集外加左表剩下数据。...从笛卡尔积角度讲,就是先从笛卡尔积中挑出ON子句条件成立记录,然后加上左表中剩余记录: ? 执行结果 下图解释了表t1和t2之间左连接操作: ?

2.2K20
  • MySQLJOIN用法

    数据库中JOIN称为连接,连接主要作用是根据两个或多个表中列之间关系,获取存在于不同表中数据。连接分为三类:内连接、外连接、全连接。...另外还有CROSS JOIN(笛卡尔积),个人认为如果要理解MySQL中JOIN各种连接,只需要理解笛卡尔积就足够了。...下图解释了表t1和t2之间内连接操作: ? 内连接 5 LEFT JOIN 左连接(LEFT JOIN)含义就是求两个表交集外加左表剩下数据。...右连接 相关教程 笛卡尔乘积_百度百科 MySQL各种join | 雕刻時光 Join查询 | liucw's blog Mysql 连接使用 | 菜鸟教程 MySQLJOIN(一):用法...- 付大石 - 博客园 MySQLJOIN(二):JOIN原理 - 付大石 - 博客园 Cartesian product - Wikipedia

    3.3K20

    Mysqllimit用法

    Mysqllimit用法 强烈推介IDEA2020.2破解激活,IntelliJ...初始记录行偏移量是 0(而不是 1): 为了与 PostgreSQL 兼容,MySQL 也支持句法: LIMIT # OFFSET #。...Sql代码 mysql> SELECT * FROM table LIMIT 5,10; // 检索记录行 6-15    //为了检索从某一个偏移量到记录集结束所有的记录行,可以指定第二个参数为...mysql> SELECT * FROM table LIMIT 5,10; // 检索记录行 6-15 //为了检索从某一个偏移量到记录集结束所有的记录行,可以指定第二个参数为 -1: mysql...【引用,路人乙:Mysql中limit用法详解】 2、Mysql分页查询语句性能分析       MySql分页sql语句,如果和MSSQLTOP语法相比,那么MySQLLIMIT语法要显得优雅了许多

    2.7K30

    mysql临时表用法

    当处理较复杂大逻辑时,你可能偶尔需要运行很多查询获得一个大量数据子集,不是对整个表运行这些查询,而是让MySQL每次找出所需少数记录,将记录存到一个临时表可能更快些,然后多这些表运行查询。...这就是mysql临时表作用了 一:创建临时表 CREATE TEMPORARY TABLE tmp_table (      name VARCHAR(10) NOT NULL,      value...如果你声明Mysql临时表是一个HEAP表,MySQL也允许你指定在内存中创建它 CREATE TEMPORARY TABLE tmp_table (      name VARCHAR(10) NOT... NULL,      value INTEGER NOT NULL      ) TYPE = HEAP 因为HEAP表存储在内存中,你对它运行查询可能比磁盘上临时表快些。...然而,HEAP表与一般表有些不同,且有自身限制。详见MySQL参考手册。

    2.8K20

    Mysql中limit用法

    目录 目录 前言 limit语法 性能分析 优化 用id优化 用覆盖索引优化 总结 前言 日常开发中,我们使用mysql来实现分页功能时候,总是会用到mysqllimit语法.而怎么使用却很有讲究...因为limit 10000,10语法实际上是mysql查找到前10010条数据,之后丢弃前面的10000行,这个步骤其实是浪费掉....用覆盖索引优化 mysql查询完全命中索引时候,称为覆盖索引,是非常快,因为查询只需要在索引上进行查找,之后可以直接返回,而不用再回数据表拿数据.因此我们可以先查出索引ID,然后根据Id拿数据....总结 用mysql做大量数据分页确实是有难度,但是也有一些方法可以进行优化,需要结合业务场景多进行测试....联系邮箱:huyanshi2580@gmail.com 更多学习笔记见个人博客——>呼延十 var gitment = new Gitment({ id: 'Mysql中limit用法', //

    11.8K20

    MYSQL用法(十五) MySQL中FIND_IN_SET()用法

    FIND_IN_SET(str,strlist) 返回str在字符串集strlist中序号(任何参数是NULL则返回NULL,如果str没找到返回0,参数1包含","时工作异常) 例子: 查询表字段...+{id},' 使用上面的语句,可以查询出来 用FIND_IN_SET() 更简单 SELECT * FROM linkinfo WHERE FIND_IN_SET('1',pingid 原来以为mysql...可以进行这样查询----->(一) select id, list, name from table where 'daodao' IN (list); 注:1. table含有三个字段id:int..., list:varchar(255), name:varchar(255) 实际上这样是不行,这样只有当name是list中第一个元素时,查询才有效,否则都不到结果,即使'daodao'真的再list...为什么第一条不能取得正确结果,而第二条却能取得结果。

    2.9K30

    mysql @value := 用法

    背景 有这么一张表,记录名字和分数,现在需要按照成绩排名,存在并列名次情况 解决方法 思路:按照score从大到小排序,第一行数据就是第一名,第二行就是第二名......需要判断当前行score和上一行...Every derived table must have its own alias -- 派生出来表都要有一个别名   新增两列表,一列是当前排名curRank,一个是上条记录score值preScore...按照score倒序排列,即score最大一行,第一名一条记录; 2....扫描完所有的记录后得到上表 case函数只返回第一个符合条件值,剩下case部分将会被自动忽略。...当有score一样情况时,@preScore=score时,@curRank并没有做+1操作,所以就有了并列情况

    5.8K91

    mysql中not exists用法_not exists用法

    大家好,又见面了,我是你们朋友全栈君。...not exists是sql中一个语法,常用在子查询和主查询之间,用于条件判断,根据一个条件返回一个布尔值,从而来确定下一步操作如何进行,not exists也是exists或in对立面。...not exists 是exists对立面,所以要了解not exists用法,我们首先了解下exists、in区别和特点: exists : 强调是是否返回结果集,不要求知道返回什么, 比如:...,那么exists这个条件就算成立了,大家注意返回字段始终为1,如果改成“select 2 from grade where …”,那么返回字段就是2,这个数字没有意义。...1,2,3 from grade where …) in子句返回了三个字段,这是不正确,exists子句是允许,但in只允许有一个字段返回,在1,2,3中随便去了两个字段即可。

    8.8K20

    MySQL replace into 用法

    Mysql中REPLACE INTO用法,判断数据是否存在,如果不存在,则插入,如果存在,则先删除此行数据,然后插入新数据 MySQL replace into 用法 在向表中插入数据时候,经常遇到这样情况...MySQL 中实现这样逻辑有个简单方法: replace into replace into t(id, update_time) values(1, now()); 或 replace into ...如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新数据。 2. 否则,直接插入新数据。 要注意是:插入数据表必须有主键或者是唯一索引!...前两种形式用多些。其中 “into” 关键字可以省略,不过最好加上 “into”,这样意思更加直观。另外,对于那些没有给予值列,MySQL 将自动为这些列赋上默认值。...官方文档参见:https://dev.mysql.com/ 图片 首发链接:https://www.cnblogs.com/lingyejun/p/16884215.html

    1.7K10

    MYSQL用法(九) 索引用法

    MySQL只需一次检索就能够找出正确结果!在没有扫描数据文件任何一个记录情况下,MySQL就正确地找出了搜索目标记录!   ...type:连接操作类型。下面是MySQL文档关于ref连接类型说明:  对于每一种与另一个表中记录组合,MySQL将从当前表读取所有带有匹配索引值记录。...Key: 它显示了MySQL实际使用索引名字。如果它为空(或NULL),则MySQL不使用索引。 key_len: 索引中被使用部分长度,以字节计。...如果MySQL只使用索引中firstname部分,则key_len将是50。 ref: 它显示是列名字(或单词“const”),MySQL将根据这些列来选择行。...在本例中,MySQL根据三个常量选择行。 rows: MySQL所认为它在找到正确结果之前必须扫描记录数。显然,这里最理想数字就是1。

    3.1K20

    mysql中exists用法详解

    前言 在日常开发中,用mysql进行查询时候,有一个比较少见关键词exists,我们今天来学习了解一下这个 exists这个sql关键词用法,这样在工作中遇到一些特定业务场景就可以有更加多样化解决方案...,该条数据保留 4、如果内层表t2不满足查询条件,则返回false,则删除该条数据 5、最终将外层所有满足条件数据进行返回 ---- 贴个链接,mysql官方对于这个命令说明: https:...//dev.mysql.com/doc/refman/8.0/en/exists-and-not-exists-subqueries.html;喜欢看英文原版说明可以来这里看一下 使用案例 环境准备...mysql版本: 8.0.28 数据库表设计: 学生表: t_student CREATE TABLE `t_student` ( `id` int unsigned NOT NULL AUTO_INCREMENT...我们明白了一个道理:内层循环次数多少不会影响到外层次数,但是外层循环次数直接会影响到内层循环次数,外层循环每多一次,内层循环就需要多完整一次循环,所以我们优化目标其实就是使外层循环次数尽量少

    4.9K50
    领券