大数据量查询慢的问题 select * from tablea where post_date>"XXXXXX"类似这样的条件查询语句,当数据库表的量比较大以后(比如几百万),执行速度会非常慢。有什么办法改进吗?数据库是mysql 引擎是myisam加索引没有用,已经试过。 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 象你这样的语句,本身就有些问题。select * from tablea where post_date>"XXXXXX"就算对post_date建立了索引,用explain观察type最多也是range级别。如果不建立索引,type是ALL。当MySQL估计检查的行数可能会”太多”,范围查找优化将不会被使用。尤其是上百万比较明显。建议换种思路。 对这个语句唯一能做的就是给post_date加索引。但是你确定你的应用程序需要所有这么多条数据吗?建议从应用程序入手,减少获取的行数~ 当你查询大量数据时,index是没用的. 1:post_date上加索引2:查询时,通过索引,可以直接定位到最后一行的INDEX位置(你用的是>),然后通过索引,去对应的磁盘位置把数据找出来,拼装。如果数据存的都是有序的,那么磁盘扫描是顺序扫描,速度很快。如果数据是无序的,比如(1,4,6100,2,13,1,34324,0),那么磁盘扫描是随机的,就会比较慢。这时候可以试试13.5.2.5. OPTIMIZE TABLE语法OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...如果您已经删除了表的一大部分,或者如果您已经对含有可变长度行的表(含有VARCHAR, BLOB或TEXT列的表)进行了很多更改,则应使用OPTIMIZE TABLE。被删除的记录被保持在链接清单中,后续的INSERT操作会重新使用旧的记录位置。您可以使用OPTIMIZE TABLE来重新利用未使用的空间,并整理数据文件的碎片。 谁能给个mysql 下载地址?? 请教个设置数据库在线人数问题。 sql sql sql 语句~~~ 关于mysql中odbc问题。谢谢 我的mysql control center 连接的时候怎么出现了错误呀!!急急,请高手解决! 怎么编辑修改MYD文件? 数据库迁移 1000.00元左右,请人做一个电子商务平台,包括数据(ASP、PHP……都可以),还有页面设计,不要很复杂,专售玩具的,要易于 mysql游标使用报错 查询工时录入!!!求大神 mysql双机热备? sql 要优化了了。。。。。
select * from tablea where post_date>"XXXXXX"
就算对post_date建立了索引,用explain观察type最多也是range级别。如果不建立索引,type是ALL。当MySQL估计检查的行数可能会”太多”,范围查找优化将不会被使用。尤其是上百万比较明显。
建议换种思路。
但是你确定你的应用程序需要所有这么多条数据吗?建议从应用程序入手,减少获取的行数~
2:查询时,通过索引,可以直接定位到最后一行的INDEX位置(你用的是>),然后通过索引,去对应的磁盘位置把数据找出来,拼装。如果数据存的都是有序的,那么磁盘扫描是顺序扫描,速度很快。如果数据是无序的,比如(1,4,6100,2,13,1,34324,0),那么磁盘扫描是随机的,就会比较慢。这时候可以试试13.5.2.5. OPTIMIZE TABLE语法
OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...
如果您已经删除了表的一大部分,或者如果您已经对含有可变长度行的表(含有VARCHAR, BLOB或TEXT列的表)进行了很多更改,则应使用OPTIMIZE TABLE。被删除的记录被保持在链接清单中,后续的INSERT操作会重新使用旧的记录位置。您可以使用OPTIMIZE TABLE来重新利用未使用的空间,并整理数据文件的碎片。