我想从另一个表更新一个表。我从一个表中选择数据:
$result2 = mysql_query ('SELECT * FROM pages_language_overlay WHERE sys_language_uid = 1', $con);
现在我想用选定的数据逐行更新多个表:
while ($row2 = mysql_fetch_array($result2)){
$updatepowerfields = "UPDATE tx_powermail_fields SET tstamp='$row2[11]' WHERE sys_language_uid = 0";
mysql_query($updatepowerfields,$con);
$updatepowerfieldsets = "UPDATE tx_powermail_fieldsets SET pid='$row2[0]', tstamp='$row2[11]', crdate='$row2[12]', cruser_id='$row2[13]',
t3ver_oid='$row2[2]', t3ver_id='$row2[3]', t3ver_wsid='$row2[4]', t3ver_label='$row2[5]', t3ver_state='$row2[6]', t3ver_stage='$row2[7]', t3ver_count='$row2[8]',
t3ver_tstamp='$row2[9]', t3_origuid='$row2[10]', deleted='$row2[19]', hidden='$row2[16]', starttime='$row2[17]', endtime='$row2[18]', title='$row2[15]'
WHERE sys_language_uid = 0";
mysql_query($updatepowerfieldsets$con);
}
它有效,但不是我的预期。在“while”的第一次迭代中,它只用一行重写整个表。我需要逐行更新这些表。我究竟做错了什么?你能帮我么?谢谢
答案 0 :(得分:4)
while ($row2 = mysql_fetch_array($result2)){
for($i = 1; $i <= sizeof($row2); i++) {
mysql_query("update fld_name = $row2[i] where $id = '$i'");
}
}
实际上你不需要while循环,因为只获取了一行!!希望有所帮助。!!