」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何解決 UNION 操作中的「錯誤:使用的 SELECT 語句具有不同的列數」?

如何解決 UNION 操作中的「錯誤:使用的 SELECT 語句具有不同的列數」?

發佈於2024-11-10
瀏覽:826

How to Resolve \

錯誤:SELECT 語句中的列計數差異

執行涉及多個SELECT 語句的查詢(例如UNION 操作)時,必須執行此操作可確保每個語句包含完全相同的列數。如果不這樣做,將導致「錯誤:所使用的 SELECT 語句具有不同的列數」錯誤。

要解決此問題,需要重寫查詢,使每個 SELECT 子句具有相同的列數具有相容資料類型的列。例如,提供的查詢:

SELECT * FROM friends
LEFT JOIN users AS u1 ON users.uid = friends.fid1
LEFT JOIN users AS u2 ON users.uid = friends.fid2
WHERE (friends.fid1 = 1) AND (friends.fid2 > 1)
UNION SELECT fid2 FROM friends
WHERE (friends.fid2  = 1) AND (friends.fid1 

遇到此錯誤,因為第一個SELECT 包含4 個欄位(「」、u1.、u2.*),而第二個SELECT 僅傳回單一欄位( “fid2” ").

保留預期功能的更直接的重寫是:

SELECT f.*, u.*
FROM FRIENDS AS f
JOIN USERS AS u ON u.uid = f.fid2
WHERE f.fid1 = 1 
  AND f.fid2 > 1
UNION 
SELECT f.*, u.*
FROM FRIENDS AS f
JOIN USERS AS u ON u.uid = f.fid1
WHERE f.fid2  = 1 
  AND f.fid1 

透過確保兩個 SELECT 語句傳回相同數量且資料類型相符的資料列,可以執行查詢而不會遇到列計數錯誤。此外,它消除了不必要的外部聯接,根據提供的模式,這些外部聯結似乎是多餘的。

最新教學 更多>
  • 為什麼我的 Keras 模型僅在資料集的一部分上進行訓練?
    為什麼我的 Keras 模型僅在資料集的一部分上進行訓練?
    Keras 訓練資料差異在按照官方TensorFlow 指南使用Keras 建立神經網路時,您注意到該模型僅使用儘管有60,000個條目,但訓練期間可用資料集的一部分。 了解批量大小模型擬合期間顯示的數字 1875 並不表示訓練樣本,而是表示批次數量。 model.fit 方法有一個可選參數,bat...
    程式設計 發佈於2024-11-18
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-18
  • 為什麼推遲 GZIP Writer 關閉會導致 Go 中的資料遺失?
    為什麼推遲 GZIP Writer 關閉會導致 Go 中的資料遺失?
    延遲GZIP Writer 關閉會導致資料遺失延遲GZIP Writer 關閉會導致資料遺失在Go 中,使用defer 關閉gzip.Writer 可能會導致意外的EOF 錯誤從壓縮資料中讀取。要解決此問題,讓我們深入研究問題的具體情況並提供替代解決方案。 理解問題:func zipData(ori...
    程式設計 發佈於2024-11-18
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-18
  • 介面如何實現超越簡單方法定義的多態性?
    介面如何實現超越簡單方法定義的多態性?
    多態性:不只是方法定義在物件導向程式設計中,介面在確保程式碼靈活性和可重用性方面發揮著至關重要的作用。雖然您正確地聲明介面只需要實作它們的類別來提供必要的方法,但它們的真正價值遠遠超出了方法聲明。 考慮您提供的範例,使用 IBox 介面和 Rectangle 類別。直接建立 IBox 實例是不可能的...
    程式設計 發佈於2024-11-18
  • 為什麼 Java 中的陣列不能保存通用項?
    為什麼 Java 中的陣列不能保存通用項?
    陣列可以儲存泛型項嗎? 泛型型別和陣列在 Java 中的互動方式不同。考慮以下程式碼:ArrayList<Key> a = new ArrayList<Key>();此程式碼編譯成功,建立一個名為 a 的通用 ArrayList。但是,下面的程式碼無法編譯通過:ArrayLi...
    程式設計 發佈於2024-11-18
  • 為什麼鍵入「String」後 Eclipse 的 Java 程式碼補全不起作用?
    為什麼鍵入「String」後 Eclipse 的 Java 程式碼補全不起作用?
    Eclipse/Java 程式碼完成故障:故障排除Eclipse 是一種流行的Java 開發環境,偶爾會遇到程式碼完成功能的問題。當使用者在輸入“String”後按下“Ctrl”“Space”時遇到程式碼完成無法產生建議的情況時,就會出現這樣的問題。該問題表現為「無預設提案」訊息,並伴隨指示未完成的...
    程式設計 發佈於2024-11-18
  • 將 fetchall() 與 MySQLDB SSCursor 結合使用對於大型資料集實際上有效嗎?
    將 fetchall() 與 MySQLDB SSCursor 結合使用對於大型資料集實際上有效嗎?
    高效利用MySQLDB SSCursor 處理大型結果集處理涉及數十萬或更多行的龐大結果集時,高效的內存管理變得尤為重要至關重要的。因此,MySQLDB SScursor(串流選擇遊標)成為最小化記憶體消耗的合適工具。 有基礎遊標的Fetchall() 與SSCursor 的差異與普遍看法相反,從S...
    程式設計 發佈於2024-11-18
  • 我如何在前端使用 Service Worker 最佳化載入時間
    我如何在前端使用 Service Worker 最佳化載入時間
    您是否遇到過網站載入時間過長的情況,如下圖所示? ?你聽過服務人員嗎? 在這篇文章中,我們將深入探討什麼是 Service Worker? 、它們如何運作 ⚙️,以及我如何使用它們來提高 Web 應用程式的效能。 什麼是 Service Worker? ? Service Worker 是一...
    程式設計 發佈於2024-11-18
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-11-18
  • 如何使用純 CSS 建立等高列?
    如何使用純 CSS 建立等高列?
    使用CSS 實現等高列在Web 開發領域,對視覺吸引力佈局的追求往往導致對等高佈局的渴望高度列。使用純 CSS 實現這種效果可能是一個挑戰,促使許多開發人員轉向背景圖片等解決方案。然而,存在著一種更簡單、更有效的方法。 垂直表格方法為了在不借助背景圖像的情況下實現等高列,“垂直表格”方法事實證明它既...
    程式設計 發佈於2024-11-18
  • 何時以及為何應使用「pip install --user...」?
    何時以及為何應使用「pip install --user...」?
    理解「pip install --user...」的目的「pip install --user...」指令在Python套件管理中具有特定用途,使用戶能夠在其本機使用者目錄中安裝套件。這與 pip 的預設行為有很大不同,pip 通常會在系統範圍的目錄中安裝軟體包,而這項任務通常需要 root 權限。...
    程式設計 發佈於2024-11-18
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-18
  • 對於具有三個「unsigned Short」成員的結構,為什麼「sizeof(myStruct)」會傳回 6 個位元組而不是 8 個位元組?
    對於具有三個「unsigned Short」成員的結構,為什麼「sizeof(myStruct)」會傳回 6 個位元組而不是 8 個位元組?
    C 結構中的記憶體對齊:了解大小差異使用C 結構時,記憶體對齊在決定實際大小方面起著至關重要的作用記憶體中結構體的大小。記憶體對齊是指將資料結構放置在可被特定邊界整除的記憶體位址中。這確保了高效的數據存取和效能優化。 考慮一個 32 位元機器,其中記憶體對齊通常設定為 4 位元組。在這種情況下,由多...
    程式設計 發佈於2024-11-18
  • 腳本標籤中的 HTML 註解還有用嗎?
    腳本標籤中的 HTML 註解還有用嗎?
    腳本標籤內的HTML 註解:一種可疑的做法許多開發人員依賴腳本標籤內的HTML 註解來防止過時的瀏覽器渲染JavaScript程式碼。然而,支援 JavaScript 的瀏覽器的激增使得這種做法在很大程度上已經過時。 為什麼消除腳本標籤中的 HTML 註解? 如今,幾乎所有瀏覽器都理解腳本區塊,即使...
    程式設計 發佈於2024-11-18

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3