首页 > 数据库 > mysql教程 > mysql的大量数据操作技巧_MySQL

mysql的大量数据操作技巧_MySQL

WBOY
发布: 2016-05-31 08:46:33
原创
1473 人浏览过

最近几天在公司导数据,主要涉及对mysql的操作,几天下来在boss的指正下算是有了一点小心得:

如ex_table表中有100万条数据,主要字段uid,username,password,email,logintime,主键uid,现需要将其中的uid取出做另外一个查询条件,如果直接选择会造成表锁死,内存溢出。如 $query=mysql_query(select * from ex_table)。

技巧一,limit分页

$query=mysql_query('select count(*) as cnt  from ex_table ' );$res=mysql_fetch_assoc($query);$cnt=$res['cnt'];$pagesize=1000;$num=ceil($cnt/$pagesize);$start=0;for($i=0;$i<$mun;$i++){      $sql="select * from ex_table limit {$start},{$pagesize}";   $start+=$pagesize;}
登录后复制

技巧二,利用uid分页;效率要高很多

$query=mysql_query(&#39;select max(uid)as max,min(uid) as min  from ex_table &#39; );$res=mysql_fetch_assoc($query);$max=$res[&#39;max&#39;];$min=$res[&#39;min&#39;];$pagesize=1000;for($i=$min;$i<=$max;){   $maxpage=$i+$pagesize;   $sql="select * from ex_table where uid<&#39;{$maxpage}&#39; and uid>='{$i}'";   $start+=$pagesize;}
登录后复制

另外还有两个分析sql性能的关键字 explain desc,具体能显示哪些性能还不是太了解。

desc/explain select from ex_table where ````

就这么多了。

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板