Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> MySQL

คัดลอกค่าคอลัมน์จากตารางหนึ่งไปยังอีก ID ที่ตรงกันใน MySQL


ให้เราสร้างตารางก่อน -

mysql> สร้างตาราง DemoTable1( PersonId int, Value int); ตกลง ตกลง 0 แถวได้รับผลกระทบ (0.64 วินาที)

แทรกระเบียนบางส่วนในตารางโดยใช้คำสั่ง insert -

mysql> แทรกลงในค่า DemoTable1 (100,78); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.46 วินาที) mysql> แทรกลงในค่า DemoTable1 (101,67); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.14 วินาที) mysql> ลงในค่า DemoTable1 (102,89); แบบสอบถามตกลง ได้รับผลกระทบ 1 แถว (0.19 วินาที)

แสดงระเบียนทั้งหมดจากตารางโดยใช้คำสั่ง select -

mysql> เลือก *จาก DemoTable1;

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

<ก่อนหน้า>+----------+-------+| รหัสบุคคล | ค่า |+----------+-------+| 100 | 78 || 101 | 67 || 102 | 89 |+----------+-------+3 แถวในชุด (0.00 วินาที)

ต่อไปนี้เป็นแบบสอบถามเพื่อสร้างตารางที่สอง

mysql> สร้างตาราง DemoTable2( StudentId int, StudentScore int);สืบค้นตกลง 0 แถวได้รับผลกระทบ (0.57 วินาที)

แทรกระเบียนบางส่วนในตารางโดยใช้คำสั่ง insert -

mysql> แทรกลงในค่า DemoTable2 (100, NULL); Query OK, 1 แถวได้รับผลกระทบ (0.20 วินาที)mysql> แทรกลงในค่า DemoTable2 (102, NULL); Query OK, 1 แถวได้รับผลกระทบ (0.22 วินาที)

แสดงระเบียนทั้งหมดจากตารางโดยใช้คำสั่ง select -

mysql> เลือก *จาก DemoTable2;

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

<ก่อนหน้า>+-----------+--------------+| รหัสนักศึกษา | StudentScore |+-----------+--------------+| 100 | NULL || 102 | NULL |+-----------+--------------+2 แถวในชุด (0.00 วินาที)

ต่อไปนี้เป็นแบบสอบถามเพื่อคัดลอกค่าคอลัมน์จากตารางหนึ่งไปยังรหัสที่ตรงกันอื่น -

mysql> อัปเดต DemoTable1, DemoTable2 ตั้งค่า DemoTable2.StudentScore =DemoTable1.Value โดยที่ DemoTable2.StudentId=DemoTable1.PersonId;Query OK, 2 แถวได้รับผลกระทบ (0.13 วินาที) แถวที่ตรงกัน:2 เปลี่ยนแปลง:2 คำเตือน:0

ให้เราตรวจสอบบันทึกตารางอีกครั้ง -

mysql> เลือก *จาก DemoTable2;

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

<ก่อนหน้า>+-----------+--------------+| รหัสนักศึกษา | StudentScore |+-----------+--------------+| 100 | 78 || 102 | 89 |+-----------+---------------------+2 แถวในชุด (0.00 วินาที)