• 技术文章 >数据库 >mysql教程

    MySQLSQL优化:SQL爬虫翻页优化_MySQL

    2016-06-01 13:17:39原创502
    赶着这几天有些时间,把前段时间优化的几条SQL经验分享并总结下,以飨来者。第一个要分享的是对MyISAM优化limit分页。背景来自公司某个业务系统提供给爬虫抓取数据。基础信息:MySQL版本是5.1,引擎为MyISAM,原始SQL内容大致如下:注:为避免敏感信息,将很多字段变为col,但不影响阅读 :-)
    SELECT Aa.* , B.col, B.col, C.col, C.col FROM (SELECT A.col, A.col, A.col, A.col , A.col, A.col, A.col, A.col, A.col, A.col, A.col , A.col FROM A WHERE A.class1id = 1000000 AND 1 ORDER BY A.oktime DESC LIMIT 286660,20) Aa LEFT JOIN B ON Aa.class2id=B.id LEFT JOIN C ON Aa.username=C.username
    SELECT Aa.* , B.col, B.col, C.col, C.col FROM (SELECT A.col, A.col, A.col, A.col , A.col, A.col, A.col, A.col, A.col, A.col, A.col , A.col FROM A INNER JOIN (SELECT askid FROM solve_answerinfo use INDEX (idx_1) WHERE class1id = 1000000 ORDER BY oktime DESC LIMIT 389300,20) aaa USING (askid)) Aa LEFT B ON Aa.class2id=B.id LEFT JOIN C ON Aa.username=C.username;
    create index idx_1 on solve_answerinfo (oktime,askid,class1id);
    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:信息
    上一篇:mysql中实现类似oracle的SYS_CONNECT_BY_PATH功能_MySQL 下一篇:spring的数据源基本配置_MySQL
    PHP编程就业班

    相关文章推荐

    • hbase与mysql的区别是什么• mysql什么是临时表• mysql怎么查询事务隔离级别• mysql中的事务是什么• mysql怎么修改事务隔离级别

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网