主页 > 知识库 > MySql如何使用not in实现优化

MySql如何使用not in实现优化

热门标签:上海市三维地图标注 南宁外呼系统招商 怎么更改高德地图标注 400电话到哪办理优惠 云南大数据外呼系统 机器人打电销电话 郑州网络外呼系统价钱 博乐电销机器人 电话机器人是电脑呼号吗

最近项目上用select查询时使用到了not in来排除用不到的主键id一开始使用的sql如下:

select 
  s.SORT_ID,
  s.SORT_NAME,
  s.SORT_STATUS,
  s.SORT_LOGO_URL,
  s.SORT_LOGO_URL_LIGHT
from SYS_SORT_PROMOTE s
  WHERE
    s.SORT_NAME = '必听经典'
    AND s.SORT_ID NOT IN ("SORTID001")
  limit 1;

表中的数据较多时这个sql的执行时间较长、执行效率低,在网上找资料说可以用 left join进行优化,优化后的sql如下:

select 
  s.SORT_ID,
  s.SORT_NAME,
  s.SORT_STATUS,
  s.SORT_LOGO_URL,
  s.SORT_LOGO_URL_LIGHT
from SYS_SORT_PROMOTE s
left join (select SORT_ID from SYS_SORT_PROMOTE where SORT_ID=#{sortId}) b
on s.SORT_ID = b.SORT_ID
  WHERE
    b.SORT_ID IS NULL
    AND s.SORT_NAME = '必听经典'
  limit 1;

上述SORT_ID=#{sortId} 中的sortId传入SORT_ID这个字段需要排除的Id值,左外连接时以需要筛选的字段(SORT_ID)作为连接条件,最后在where条件中加上b.SORT_ID IS NULL来将表中的相关数据筛选掉就可以了。

这里写下随笔,记录下优化过程。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • MYSQL IN 与 EXISTS 的优化示例介绍
  • MySQL中对于not in和minus使用的优化
  • MySQL中or、in、union与索引优化详析
  • MySQL之select in 子查询优化的实现
  • 一次Mysql使用IN大数据量的优化记录

标签:宁夏 杭州 澳门 定西 秦皇岛 益阳 恩施 白银

巨人网络通讯声明:本文标题《MySql如何使用not in实现优化》,本文关键词  MySql,如何,使用,not,实现,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《MySql如何使用not in实现优化》相关的同类信息!
  • 本页收集关于MySql如何使用not in实现优化的相关信息资讯供网民参考!
  • 推荐文章