สำหรับการอัปเดตค่าในตาราง MySQL หนึ่งตารางโดยใช้ค่าจากตาราง MySQL อื่น เราจำเป็นต้องใช้ sub-query เป็นนิพจน์ใน SET clause ของคำสั่ง UPDATE
ตัวอย่าง
ในตัวอย่างนี้ เรามีสองตาราง 'นักเรียน' และ 'ข้อมูล' เราจะอัปเดตค่าคอลัมน์ 'เกรด' ของตาราง 'นักเรียน' โดยใช้ค่าจากคอลัมน์ 'หมายเหตุ' ของตาราง 'ข้อมูล'
mysql> select * from student; +----+---------+-------+ | Id | Name | grade | +----+---------+-------+ | 1 | Rahul | NULL | | 2 | Gaurav | NULL | | 3 | Raman | NULL | | 4 | Harshit | NULL | | 5 | Aarav | NULL | +----+---------+-------+ 5 rows in set (0.01 sec) mysql> select * from info; +------+-----------+ | id | remarks | +------+-----------+ | 1 | Good | | 2 | Good | | 3 | Excellent | | 4 | Average | | 5 | Best | +------+-----------+ 5 rows in set (0.00 sec) mysql> UPDATE STUDENT SET grade = (SELECT remarks from info WHERE info.id = student.id) WHERE id > 0; Query OK, 5 rows affected (0.08 sec) Rows matched: 5 Changed: 5 Warnings: 0
ข้อความค้นหาด้านบนโดยใช้แบบสอบถามย่อยจะอัปเดตค่าในคอลัมน์เกรดของตาราง "นักเรียน" สามารถสังเกตได้จากชุดผลลัพธ์ที่ส่งคืนโดยทำตามการสืบค้น MySQL
mysql> Select * from student; +----+---------+-----------+ | Id | Name | grade | +----+---------+-----------+ | 1 | Rahul | Good | | 2 | Gaurav | Good | | 3 | Raman | Excellent | | 4 | Harshit | Average | | 5 | Aarav | Best | +----+---------+-----------+ 5 rows in set (0.00 sec)