zoukankan      html  css  js  c++  java
  • 解决mysql中limit和in不能同时使用的问题

    先给出数据表

    CREATE TABLE `test_tb_grade` (
      `ID` int(10) NOT NULL AUTO_INCREMENT,
      `USER_NAME` varchar(20) DEFAULT NULL,
      `COURSE` varchar(20) DEFAULT NULL,
      `SCORE` float DEFAULT '0',
      PRIMARY KEY (`ID`)
    ) ENGINE=InnoDB AUTO_INCREMENT=28 DEFAULT CHARSET=utf8

    对应的语句

    insert  into `test_tb_grade`(`ID`,`USER_NAME`,`COURSE`,`SCORE`) values (19,'张三','语文',34),(20,'张三','数学',58),(21,'张三','英语',58),(22,'李四','数学',45),(23,'李四','语文',87),(24,'李四','英语',45),(25,'王五','数学',76),(26,'王五','语文',34),(27,'王五','英语',89);

    有时会我们会写出这样的语句

    SELECT * FROM test_tb_grade
    WHERE id IN (SELECT id FROM test_tb_grade LIMIT 0,5);

    看上去没啥没什么毛病,但是一执行就会出现这样的错

    <e>查询:select * from test_tb_grade where id in (SELECT id from test_tb_grade limit 0,5) LIMIT 0, 1000
    
    错误代码: 1235
    This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery'

    原因是mysql的这个版本是不支持in里面的语句使用limit

    解决方式有两种

    第一种,通过使用伪表的方式,进行表连接操作。

    SELECT a.*,b.*
    FROM test_tb_grade  a
    INNER JOIN (SELECT id FROM test_tb_grade  LIMIT 0,5) b
    ON a.id = b.id

    第二种,将in语句里面的查询再包装一层,绕过去即可。

    SELECT * FROM test_tb_grade
    WHERE id IN 
    (SELECT sc.id FROM (SELECT id FROM test_tb_grade LIMIT 0,5)AS sc);

    两种方式推荐第一种。避免了in语句。进行explain诊断会发现第一种效率高很多。

    记录下sql语句的完整执行顺序

    1、from子句组装来自不同数据源的数据;
     2、where子句基于指定的条件对记录行进行筛选; 
    3、group by子句将数据划分为多个分组; 
    4、使用聚集函数进行计算;
    5、使用having子句筛选分组; 
    6、计算所有的表达式; 
    7、使用order by对结果集进行排序。

  • 相关阅读:
    C++学习笔记----2.4 C++对象的内存模型
    C++学习笔记(2)---2.5 C++函数编译原理和成员函数的实现
    C++学习笔记(1)-构造函数与析构函数
    学习笔记(5)---数学运算
    学习笔记(4)---协方差和特征向量的意义
    学习笔记(3)---安装SVM问题及解决方法
    学习笔记(2)---Matlab 图像处理相关函数命令大全
    数据增删查改操作总结
    表操作总结
    touch命令修改时间
  • 原文地址:https://www.cnblogs.com/chywx/p/9946813.html
Copyright © 2011-2022 走看看