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

MySQL ใดส่งคืนหากแบบสอบถามย่อยใช้เพื่อกำหนดค่าใหม่ในส่วนคำสั่ง SET ของคำสั่ง UPDATE ส่งคืนหลายแถว


ในกรณีนี้ MySQL จะส่งคืนข้อความแสดงข้อผิดพลาดเนื่องจากเรารู้ว่าหากใช้ sub-query เพื่อกำหนดค่าใหม่ในส่วนคำสั่ง SET ของคำสั่ง UPDATE จะต้องส่งคืนหนึ่งแถวสำหรับแต่ละแถวในตารางการอัพเดทที่ตรงกับส่วนคำสั่ง WHERE .

ตัวอย่าง

mysql> insert into info(id, remarks) values(5,'average');
Query OK, 1 row affected (0.06 sec)

mysql> select * from info;
+------+-----------+
| id   | remarks   |
+------+-----------+
| 1    | Good      |
| 2    | Good      |
| 3    | Excellent |
| 4    | Average   |
| 5    | Best      |
| 5    | average   |
+------+-----------+
6 rows in set (0.00 sec)

ดังที่เราเห็นข้างต้น ตาราง 'ข้อมูล' มีสองแถวที่มี id =5 ดังนั้นเมื่อเราจะใช้มันในแบบสอบถามย่อยก็จะส่งคืนหลายแถวและเนื่องจาก MySQL นี้จะส่งคืนข้อความแสดงข้อผิดพลาดดังนี้ -

mysql> UPDATE STUDENT SET grade = (SELECT remarks from info WHERE info.id = student.id) WHERE id = 5;
ERROR 1242 (21000): Subquery returns more than 1 row