吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 899|回复: 4
收起左侧

[求助] SQL not in语句优化

[复制链接]
utibet田同学 发表于 2021-1-17 15:06
需求:在B表(上报情况)中找出今日没有上报的同学,参照A表(学生名单)。

目前方法:
select number,name,class,org_id from student_info where  number not in( SELECT number from sub_log where TO_DAYS(time) = TO_DAYS(NOW()))



SELECT  stu.number, stu.name, stu.class, stu.org_id
FROM    student_info stu
        LEFT JOIN sub_log sub
            ON  stu.number = sub.number AND
                TO_DAYS(time) = TO_DAYS(NOW())
WHERE   sub.number IS NULL


执行速度都在30s左右了

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

不忘初心哟 发表于 2021-1-17 16:02
本帖最后由 不忘初心哟 于 2021-1-17 16:06 编辑

number  有没有走聚集索引?  而且根据你的要求,今日没有上报 这个条件,在和log表有关系时,本人感觉用not exists更好
不忘初心哟 发表于 2021-1-17 16:07
stu.number,这个为确定且有限的集合时, not in/in 效率才会高
VioletKiss 发表于 2021-1-18 11:13
你有多少条数据啊,我造了100万条数据,加上time的索引,执行你的第一条 sql 也只是 2s 多而已

image.png
singledog 发表于 2021-1-19 14:30
SELECT  stu.number, stu.name, stu.class, stu.org_id
FROM    student_info stu
WHERE  sub.number IS NULL AND NOT EXISTS (
        SELECT 1 from sub_log sub
            WHERE  stu.number = sub.number AND
                TO_DAYS(time) = TO_DAYS(NOW() )
换成这种EXISTS 执行下试试
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-26 04:27

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表