解決「子查詢返回多於1 行」錯誤
處理子查詢時,了解它們傳回多個行的可能性至關重要行。如果處理不當,可能會導致錯誤,例如「子查詢傳回超過 1 行」錯誤。
子查詢傳回多個值
癥結所在此問題的原因在於所涉及的子查詢傳回多行。當主查詢中指定的條件依賴於從子查詢取得的值時,就會出現此錯誤。
對多個值使用 IN
要解決此問題,應使用 IN 運算子。與需要單一值的等式 (=) 運算子不同,IN 允許指定多個值。將IN 與子查詢結合使用的語法為:
select * <br>from table<br>where id IN (子查詢);<br>
在此範例中,子查詢將傳回多個值,並且表的id欄位會與其中任何一個值進行比對
範例:
例如,請考慮以下查詢:
SELECT *<br>FROM🎜><br><pre class="brush:php;toolbar:false">SELECT *FROM🎜><p></p><pre class="brush:php;toolbar:false">SELECT *<br>FROM🎜><br><pre class="brush:php;toolbar:false">SELECT *FROM Students<pre class="brush:php;toolbar:false"> (SELECT Marks FROM Students ORDER BY Marks DESC LIMIT 10); -- Returns 10 values
FROM Students
WHERE Marks IN在第一個查詢中,子傳回最大標記,它是單一值。因此,可以使用相等運算子(=)。然而,在第二個查詢中,子查詢會傳回前 10 個標記,它們是多個值。因此,需要使用IN運算子。 透過使用IN,可以有效處理傳回多行的子查詢,確保主查詢中的條件得到適當滿足,解決「子查詢回傳多於1行」的問題有效地出錯。以上是如何處理傳回多行的子查詢?的詳細內容。更多資訊請關注PHP中文網其他相關文章!