simplequery($q);"/> simplequery($q);">
Heim >Backend-Entwicklung >PHP-Tutorial >mysql用php如何分批处理插入?比如前1000条数据处理结束后,再处理1001至2000条,然后再处理2001至3000条…直到全部处理完毕
mysql用php怎么分批处理插入?比如前1000条数据处理结束后,再处理1001至2000条,然后再处理2001至3000条……,直到全部处理完毕?
当表 member中数据量不大时,可以一次性执行:
$q="select * from member'";<br />$r=$obj_db->simplequery($q);<br />while($a=$obj_db->fetchrow($r,DB_FETCHMODE_ASSOC)){<br /> $id=$a[id];<br /> $mccd=$a[cca]+$a[ccb];<br /> <br /> $query="insert into mingxi (mid,mccd,mtime) values ('$id','$mccd','$time')";<br /> $obj_db->simplequery($query);<br />}
$q="select * from member'";<br />$r=$obj_db->simplequery($q);<br />while($a=$obj_db->fetchrow($r,DB_FETCHMODE_ASSOC)){<br />$i++;<br /><br />$ep=1000;//这里假设处理完第1个1000条后再处理第二个1000条,直至处理结束?<br /><br /> $id=$a[id];<br /> $mccd=$a[cca]+$a[ccb];<br /> <br /> $query="insert into mingxi (mid,mccd,mtime) values ('$id','$mccd','$time')";<br /> $obj_db->simplequery($query);<br />}
$offs = isset($_GET['offs']) ? $_GET['offs'] : 1;<br />$sql = "select * from member limit $offs, 1000";<br />//做你该做的事<br />header("Location: $_SERVER[PHP_SELF]?offs=" . ($offs+1000));<br />