首頁 > 資料庫 > mysql教程 > 如何修復 SQL Server 中的「子查詢傳回超過 1 個值」錯誤?

如何修復 SQL Server 中的「子查詢傳回超過 1 個值」錯誤?

Patricia Arquette
發布: 2025-01-17 15:02:10
原創
559 人瀏覽過

How to Fix

解決SQL Server中子查詢傳回多個值的問題

執行以下查詢時:

<code class="language-sql">SELECT 
   orderdetails.sku,
   orderdetails.mf_item_number,
   orderdetails.qty,
   orderdetails.price,
   supplier.supplierid,
   supplier.suppliername,
   supplier.dropshipfees,
   cost = (SELECT supplier_item.price
           FROM   supplier_item,
                  orderdetails,
                  supplier
           WHERE  supplier_item.sku = orderdetails.sku
                  AND supplier_item.supplierid = supplier.supplierid)
FROM   orderdetails,
       supplier,
       group_master
WHERE  invoiceid = '339740'
       AND orderdetails.mfr_id = supplier.supplierid
       AND group_master.sku = orderdetails.sku  </code>
登入後複製

會遇到以下錯誤:

<code>Msg 512, Level 16, State 1, Line 2
子查询返回多个值。当子查询位于 =、!=、<、<=、>、>= 之后,或者用作表达式时,这是不允许的。</code>
登入後複製

此錯誤是因為 cost 表達式中使用的子查詢傳回多個值,而使用等號運算子 (=) 進行比較時不允許這種情況。要解決這個問題,請使用明確選擇 cost 列單一值的連接操作替換子查詢:

<code class="language-sql">SELECT
    od.Sku,
    od.mf_item_number,
    od.Qty,
    od.Price,
    s.SupplierId,
    s.SupplierName,
    s.DropShipFees,
    si.Price as cost
FROM
    OrderDetails od
    INNER JOIN Supplier s on s.SupplierId = od.Mfr_ID
    INNER JOIN Group_Master gm on gm.Sku = od.Sku
    INNER JOIN Supplier_Item si on si.SKU = od.Sku and si.SupplierId = s.SupplierID
WHERE
    od.invoiceid = '339740'</code>
登入後複製

此查詢現在將為 cost 列傳回單一值,從而解決子查詢錯誤。

以上是如何修復 SQL Server 中的「子查詢傳回超過 1 個值」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板