mysql limit 用法与mysql limit 优化

mysql教程 limit 用法与mysql limit 优化
/*
mysql limit 用法2007年11月08日 14:291. select * from tablename <条件语句> limit 100,15

从100条记录后开始取15条 (实际取取的是第101-115条数据)

2. select * from tablename <条件语句> limit 100,-1

从第100条后开始-最后一条的记录

3. select * from tablename <条件语句> limit 15

相当于limit 0,15   .查询结果取前15条数据
 

下面来看看limit 优化方法,首先保存1000000条记录如下。
*/  
set_time_limit(0);
mysql_connect('localhost','root','root');
mysql_select_db('accc');
mysql_query("set names 'gb2312'");
echo '正在导入数据....';
for( $i=0;$i<=1000000;$i++)
{
$sql ="insert cn_loupan_news(cityid,zid,tid,did,title,body,click,litpic,sendname,header,recommend,hot,flash,setindex,opencomment,cityname,keywords,desciption,color,b,senddate,lid,nfrom,title2,zt)values('11','2','1','1','测试数据','测试数据','88','/aa/gigf.gif','aaaa','0','0','0','0','0','0','222','222','gsfdsgfds','1','1','124567124','0','fdafda','f','fdafa')";
mysql_query($sql) or die(mysql_error());
}
echo '成功导入100万数据';
/*
select id
from `cn_loupan_news`
order by id desc
limit 800001 , 20
按主关键词排排序查询时间为 显示行 0 - 19 (20 总计, 查询花费 0.2712 秒)

select *
from `cn_loupan_news`
order by id desc
limit 800001 , 20

显示行 0 - 19 (20 总计, 查询花费 4.3221 秒)

从这里看如何选择id主索引的,排序速度还理想,假如是*号再带排序查询时间4秒多啊,不可取的方法。

select *
from cn_loupan_news
where id >= (
select id
from cn_loupan_news
limit 800000 , 1 )
limit 10

显示行 0 - 9 (10 总计, 查询花费 0.2456 秒)

稍稍好了一点。

本站原创文章转载注明来源于http://www.111cn.net/database/database.html

时间: 2024-10-02 17:12:29

mysql limit 用法与mysql limit 优化的相关文章

MySQL索引用法实例分析_Mysql

本文实例分析了MySQL索引用法.分享给大家供大家参考,具体如下: MYSQL描述: 一个文章库,里面有两个表:category和article.category里面有10条分类数据.article里面有20万条.article里面有一个"article_category"字段是与category里的"category_id"字段相对应的.article表里面已经把 article_category字义为了索引.数据库大小为1.3G. 问题描述: 执行一个很普通的查

MYSQL分页limit速度太慢的优化方法_Mysql

在mysql中limit可以实现快速分页,但是如果数据到了几百万时我们的limit必须优化才能有效的合理的实现分页了,否则可能卡死你的服务器哦.    当一个表数据有几百万的数据的时候成了问题!    如 * from table limit 0,10 这个没有问题 当 limit 200000,10 的时候数据读取就很慢,可以按照一下方法解决     第一页会很快    PERCONA PERFORMANCE CONFERENCE 2009上,来自雅虎的几位工程师带来了一篇"Efficient

mysql limit 大数据量分页优化方法

Mysql的优化是非常重要的.其他最常用也最需要优化的就是limit.Mysql的limit给分页带来了极大的方便,但数据量一大的时候,limit的性能就急剧下降. 同样是取10条数据 select * from yanxue8_visit limit 10000,10 和 select * from yanxue8_visit limit 0,10 就不是一个数量级别的. 网上也很多关于limit的五条优化准则,都是翻译自Mysql手册,虽然正确但不实用.今天发现一篇文章写了些关于limit优

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

 为什么标题要起这个名字呢?commen sence指的是那些大家都应该知道的事情,但往往大家又会会略这些东西,或者对这些东西一知半解,今天我总结下自己在mysql中遇到的一些commen sense类型的问题. 1.varchar(5)可以存储多少个汉字,多少个字母数字? 相信有好多人应该跟我一样,对这个已经很熟悉了,根据经验我们能很快的做出决定,比如说用varchar(200)去存储url等等,但是,即使你用了很多次也很熟悉了,也有可能对上面的问题做出错误的回答. 这个问题我查了好多资料,有

MySQL的分页查询语句limit

问题描述 MySQL的分页查询语句limit 假设,一个表中有一百条数据,我要查询第5页,每页10条数据,SQL语句怎么写?是用limit么? 不用涉及到Java语言,就SQL语句 解决方案 SELECT * FROM table LIMIT 51,10; 解决方案二: 查询第m页,每页n条数据 SELECT * FROM tablename LIMIT (m-1)*n,n 解决方案三: SELECT * FROM tablename LIMIT 5,10 解决方案四: SELECT * FRO

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

为什么标题要起这个名字呢?commen sence指的是那些大家都应该知道的事情,但往往大家又会会略这些东西,或者对这些东西一知半解,今天我总结下自己在mysql中遇到的一些commen sense类型的问题. 1.varchar(5)可以存储多少个汉字,多少个字母数字? 相信有好多人应该跟我一样,对这个已经很熟悉了,根据经验我们能很快的做出决定,比如说用varchar(200)去存储url等等,但是,即使你用了很多次也很熟悉了,也有可能对上面的问题做出错误的回答. 这个问题我查了好多资料,有的

MySQL查询优化:连接查询排序limit(join、order by、limit语句)

MySQL查询优化:连接查询排序limit(join.order by.limit语句) 不知道有没有人碰到过这样恶心的问题:两张表连接查询并limit,SQL效率很高, 但是加上order by以后,语句的执行时间变的巨长,效率巨低. www.bitsCN.com 情况是这么一个情况:现在有两张表,team表和people表,每个people属于一个 team,people中有个字段team_id. 下面给出建表语句: [sql] create table t_team ( id int pr

关于一个MYSQL异常问题的追查及优化

问题 用户工单疑问:相同的语句,只是最后的limit行数不同.奇怪的是,limit 10 的性能比limit 100的语句还慢约10倍. 隐藏用户表信息,语句及结果如下 SELECT f1 , SUM(`f2`) `CNT` FROM T WHERE f1 IS NOT NULL AND f3 = '2014-05-12′ GROUP BY f1 ORDER BY `CNT` DESC LIMIT 10; 执行时间3 min 3.65 sec SELECT f1 , SUM(`f2`) `CNT

MySQL 5.5.49 大内存优化配置文件优化详解_Mysql

一.配置文件说明 my-small.cnf my-medium.cnf my-large.cnf my-huge.cnf my-innodb-heavy-4G.cnf  二.详解 my-innodb-heavy-4G.cnf三.配置文件优化 注:环境说明,CentO5.5 x86_64+MySQL-5.5.32 相关软件下载:http://yunpan.cn/QtaCuLHLRKzRq 一.配置文件说明 Mysql-5.5.49是Mysql5.5系列中最后一个版本,也是最后一个有配置文件的版本,