您的位置
主页 > 网站技术 > 数据库 > » 正文

深入研究mysql中的varchar和limit(容易被忽略的知识)(3)

来源: 锦尚中国 点击:

  我自己测试了下,在一张innodb表中去使用limit,表中10000条数据,四个字段,id(int)、time(int)、title(varchar)、body(mediumtext),大小大约170M左右,首先关掉查询缓存,免得查询缓存对查询时间有影响,这里要注意time字段上面加了索引,

复制代码 代码如下:


SET @@query_cache_type=ON;
SET GLOBAL query_cache_size=0;


  打开Query profiler来查看语句执行所花费的时间

复制代码 代码如下:


set profiling=1;


  接下来对下面几个语句进行执行

复制代码 代码如下:


a、SELECT id,TIME,title FROM cnblogs WHERE TIME>=1315646940 ORDER BY TIME ASC LIMIT 2000,10

  b、SELECT id,TIME,title FROM cnblogs WHERE TIME>=1315646940 ORDER BY TIME ASC LIMIT 10

     c、 SELECT id,TIME,title FROM cnblogs ORDER BY TIME ASC LIMIT 3000,10

执行顺序a,b,c,a,b,c,c,a,a(这里需要注意下,虽然我关闭了缓存,但是上一次的查询还是会缓存,这个可以从Query profiler中看出来,所以进行交叉执行),使用下面的语句查看结果

复制代码 代码如下:


SHOW profiles;




首页  - 关于站长圈  - 广告服务  - 联系我们  - 关于站长圈  - 网站地图  - 版权声明