ฉันมีสองตารางทั้งสองดูเหมือน
id name value
===================
1 Joe 22
2 Derk 30
ฉันต้องการคัดลอกค่าvalue
จากtableA
เป็นtableB
ตามชื่อเช็คในแต่ละตาราง
มีคำแนะนำสำหรับUPDATE
คำชี้แจงนี้ไหม?
ฉันมีสองตารางทั้งสองดูเหมือน
id name value
===================
1 Joe 22
2 Derk 30
ฉันต้องการคัดลอกค่าvalue
จากtableA
เป็นtableB
ตามชื่อเช็คในแต่ละตาราง
มีคำแนะนำสำหรับUPDATE
คำชี้แจงนี้ไหม?
คำตอบ:
นอกจากคำตอบนี้หากคุณต้องการเปลี่ยน tableB.value ตาม tableA.value แบบไดนามิกคุณสามารถทำได้เช่น:
UPDATE tableB
INNER JOIN tableA ON tableB.name = tableA.name
SET tableB.value = IF(tableA.value > 0, tableA.value, tableB.value)
WHERE tableA.name = 'Joe'
UPDATE participants_registrations INNER JOIN participants ON participants.id = participants_registrations.participantId INNER JOIN registrations ON registrations.id = participants_registrations.registrationId LEFT JOIN groups ON (groups.id = registrations.groupId) SET registrations.groupId = groups.id, registrations.groupName = groups.name, participants.memberOfGroupName = groups.name
คุณต้องเข้าร่วมสองตาราง:
ตัวอย่างเช่นคุณต้องการคัดลอกค่าname
จาก tableA ไปยังtableB
ที่ที่พวกเขามีเหมือนกันID
UPDATE tableB t1
INNER JOIN tableA t2
ON t1.id = t2.id
SET t1.name = t2.name
WHERE t2.name = 'Joe'
อัพเดท 1
UPDATE tableB t1
INNER JOIN tableA t2
ON t1.id = t2.id
SET t1.name = t2.name
อัพเดท 2
UPDATE tableB t1
INNER JOIN tableA t2
ON t1.name = t2.name
SET t1.value = t2.value
where
ประโยคหรือแก้ไขwhere
ประโยคได้ตามความต้องการของคุณ ..
ความเป็นไปได้ที่สองคือ
UPDATE TableB
SET TableB.value = (
SELECT TableA.value
FROM TableA
WHERE TableA.name = TableB.name
);
.name
มีการจัดทำดัชนีในตารางทั้งสอง?
ตัวเลือกที่สองเป็นไปได้เช่นกันหากคุณกำลังใช้โหมดการอัพเดทที่ปลอดภัย (และคุณได้รับข้อผิดพลาดที่ระบุว่าคุณได้พยายามอัปเดตตารางโดยไม่ใช้ตำแหน่งที่ใช้คอลัมน์ KEY) โดยการเพิ่ม:
UPDATE TableB
SET TableB.value = (
SELECT TableA.value
FROM TableA
WHERE TableA.name = TableB.name
)
**where TableB.id < X**
;
UPDATE cities c,
city_langs cl
SET c.fakename = cl.name
WHERE c.id = cl.city_id
เก็บข้อมูลของคุณในตารางชั่วคราว
Select * into tempTable from table1
ตอนนี้อัปเดตคอลัมน์
UPDATE table1
SET table1.FileName = (select FileName from tempTable where tempTable.id = table1.ID);
ในกรณีของฉันทางออกที่ยอมรับก็ช้าเกินไป สำหรับตารางที่มีแถว 180K อัตราการอัปเดตอยู่ที่ประมาณ 10 แถวต่อวินาที นี่คือกับดัชนีในองค์ประกอบเข้าร่วม
ในที่สุดฉันก็แก้ไขปัญหาของฉันโดยใช้ขั้นตอน:
CREATE DEFINER=`my_procedure`@`%` PROCEDURE `rescue`()
BEGIN
declare str VARCHAR(255) default '';
DECLARE n INT DEFAULT 0;
DECLARE i INT DEFAULT 0;
DECLARE cur_name VARCHAR(45) DEFAULT '';
DECLARE cur_value VARCHAR(10000) DEFAULT '';
SELECT COUNT(*) FROM tableA INTO n;
SET i=0;
WHILE i<n DO
SELECT namea,valuea FROM tableA limit i,1 INTO cur_name,cur_value;
UPDATE tableB SET nameb=cur_name where valueb=cur_value;
SET i = i + 1;
END WHILE;
END
ฉันหวังว่ามันจะช่วยให้ใครบางคนในอนาคตเหมือนจะช่วยฉัน
หากคุณมีเขตข้อมูลทั่วไปในตารางทั้งสองแล้วมันง่ายมาก! ....
Table-1 = ตารางที่คุณต้องการอัพเดท Table-2 = ตารางที่คุณไม่รับข้อมูล
$qry_asseet_list = mysql_query("SELECT 'primary key field' FROM `table-1`");
$resultArray = array();
while ($row = mysql_fetch_array($qry_asseet_list)) {
$resultArray[] = $row;
}
foreach($resultArray as $rec) {
$a = $rec['primary key field'];
$cuttable_qry = mysql_query("SELECT * FROM `Table-2` WHERE `key field name` = $a");
$cuttable = mysql_fetch_assoc($cuttable_qry);
echo $x= $cuttable['Table-2 field']; echo " ! ";
echo $y= $cuttable['Table-2 field'];echo " ! ";
echo $z= $cuttable['Table-2 field'];echo " ! ";
$k = mysql_query("UPDATE `Table-1` SET `summary_style` = '$x', `summary_color` = '$y', `summary_customer` = '$z' WHERE `summary_laysheet_number` = $a;");
if ($k) {
echo "done";
} else {
echo mysql_error();
}
}
INNER JOIN
มันสมบูรณ์แบบในสถานการณ์นี้ ฉันเคยCONCAT_WS
รวมชื่อ