In diesem Fall gibt MySQL eine Fehlermeldung zurück, da wir wissen, dass, wenn Sie eine Unterabfrage verwenden, um einen neuen Wert in der SET-Klausel der UPDATE-Anweisung zuzuweisen, für jede übereinstimmende Zeile in der Aktualisierung eine Zeile zurückgegeben werden muss Tabelle WHERE-Klausel.
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)
Wie wir oben gesehen haben, hat die Tabelle „info“ zwei Zeilen mit der ID = 5. Wenn wir sie also in einer Unterabfrage verwenden, werden mehrere Zeilen zurückgegeben, sodass MySQL eine Fehlermeldung wie folgt zurückgibt: < /p>
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
Das obige ist der detaillierte Inhalt vonWas gibt MySQL zurück, wenn die Unterabfrage, die zum Zuweisen eines neuen Werts in der SET-Klausel einer UPDATE-Anweisung verwendet wird, mehrere Zeilen zurückgibt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!