mysql 一次更新(update)多条记录的思路
工作中遇到一个问题:要更新一个数据表。
这个表是我自己创建的,有7个字段,id、name、package等等
创建的时候,因为我把name、package的信息分别存在两个文本文件中,
所以我就用Insert方法,一次性将所有的name插入数据库中。
name全部导入数据库中了,但是我的package没有导入,这时我仍然想用insert的方法插入,但是不行。
这时候应该利用update的方法。一次更新多条信息的思路如下:
UPDATEtable_name SETfield_name=CASEother_field WHEN1THEN'value' WHEN2THEN'value' WHEN3THEN'value' END WHEREidIN(1,2,3) 测试代码如下: <?php /* *function:insertapp'sapk,logo_url,document_title,app_desc,package_name *intotalbeatableusedatabasedb. */ //connectdatabasecatx. $server='localhost'; $user='root'; $passwd='root'; $port='3306'; $dbname='catx'; $link=mysql_connect($server,$user,$passwd); if(!$link){ die('Couldnotconnect:'.mysql_error()); } elseecho"Connectedsuccessfully\n"; mysql_select_db("db",$link); //setinitvariableandstarttime $st=microtime_float(); $table="pydot_g"; $path="txt"; $fname_package_name="package_name.txt"; // $handle=@fopen($path."/".$fname_package_name,"r"); $i=1; $sql="UPDATEpydot_gSETpackage_name=CASEid"; $ids=""; while(($buf[$i]=fgets($handle,512))!==false){ $sql.=sprintf("WHEN%dTHEN'%s'",$i,$buf[$i]);//拼接SQL语句 $ids.=sprintf("%d,",$i); $i++; } //$ids=implode(',',$ids); $ids.=$i; $sql.="ENDWHEREidIN($ids)"; echo$sql; mysql_query($sql); fclose($handle); mysql_close($link); //echotheresultsandtotaltimeused $et=microtime_float(); $t=$et-$st; echo"\r\ninsertintotalbe",$table,"",$i,"times;\r\n"; echo"Totaltime$tseconds.\r\n"; //functioncalculatetime,returnafloatnumber functionmicrotime_float(){ list($usec,$sec)=explode("",microtime()); return((float)$usec+(float)$sec); } ?>