mysql的大量数据操作技巧

最近几天在公司导数据,主要涉及对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('select max(uid)as max,min(uid) as min  from ex_table ' );

$res=mysql_fetch_assoc($query);

$max=$res['max'];
$min=$res['min'];
$pagesize=1000;

for($i=$min;$i<=$max;){
   $maxpage=$i+$pagesize;
   $sql="select * from ex_table where uid<'{$maxpage}' and uid>='{$i}'";
   $start+=$pagesize;
}

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

desc/explain select from ex_table where ````

就这么多了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值