」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何從 MySQL 中的多個欄位中選擇不同的值組合?

如何從 MySQL 中的多個欄位中選擇不同的值組合?

發佈於2024-11-17
瀏覽:105

How to Select Distinct Value Combinations from Multiple Columns in MySQL?

在MySQL 中從多列中選擇不同的值

使用資料庫時,通常需要從多列中檢索唯一的值組合。但是,使用 DISTINCT 關鍵字可能無法總是產生所需的結果。本文探討了從 MySQL 資料庫中的兩列中選擇不同值的另一種方法。

考慮以下名為「foo_bar」的表格:

]
foo
ac
cc
cf
da
ca
ca
fc
ac
dc
da
a

]

c
SELECT DISTINCT foo, bar FROM foo_bar;

c

acafcSELECT DISTINCT foo, bar FROM foo_bar;產生下列結果:foo
使用下列SQL 語句查詢此表:
bar
ac
c

f

SELECT foo, bar FROM foo_bar GROUP BY foo, bar;

f

dacafc雖然此查詢可確保僅傳回每個唯一值組合的一個實例,但它並不能消除兩列中值交換的冗餘。例如,「a c」和「c a」都是不同的組合,但它們引用相同的資料。 SELECT foo, bar FROM foo_bar GROUP BY foo, bar;此查詢返回以下結果:
要解決這個問題,我們可以使用GROUP BY 子句:

How to Select Distinct Value Combinations from Multiple Columns in MySQL? 
foo

bar

foo

bar

aaccd如您所見,GROUP BY 子句有效地將所有重複行合併為一行消除重複並提供foo 和bar 列中真正不同的值組合。
c
f
f
a
最新教學 更多>
  • 為什麼我的 Tomcat 伺服器顯示「所需的幾個連接埠已在使用中」?
    為什麼我的 Tomcat 伺服器顯示「所需的幾個連接埠已在使用中」?
    Tomcat 伺服器連接埠衝突:解決錯誤「Several Ports required are Already in Use」嘗試在Tomcat 上啟動JSP 程式時Eclipse 中,使用者可能會遇到錯誤,指出Tomcat 所需的多個連接埠已在使用中。出現此問題的原因是存在另一個 Tomcat 實...
    程式設計 發佈於2024-11-17
  • 如何在 Java 中確定文件建立日期?
    如何在 Java 中確定文件建立日期?
    在Java 中確定文件創建日期:揭示文件元數據確定文件的創建日期可能是一條有價值的信息,尤其是組織和管理文件時。 Java 提供了存取此元資料的機制,只要底層檔案系統支援即可。 Java 中的檔案建立日期Java NIO(新輸入/輸出)提供用於擷取檔案元資料的選項,包括建立時間。透過利用 Basic...
    程式設計 發佈於2024-11-17
  • 如何在 PHP 和 MySQL 中同步時區?
    如何在 PHP 和 MySQL 中同步時區?
    在PHP 和MySQL 中同步時區您正在開發一個需要使用PHP date() 函數在MySQL 中儲存日期的應用程式。有必要使用 NOW() 在 MySQL 中比較這些日期來計算時間差異。但是,PHP date() 函數使用 PHP 中定義的時區,而 NOW() 使用 MySQL 伺服器中配置的時區...
    程式設計 發佈於2024-11-17
  • 我們如何在 C/C++ 中實作鋸齒狀數組?
    我們如何在 C/C++ 中實作鋸齒狀數組?
    理解C/C 中的交錯數組雖然交錯數組的概念(其中行可以有不同的長度)在標準C/ C ,有一些技術可以實現類似的功能。 在嘗試在C/C 中宣告交錯數組時,如圖所示:int jagged[][] = { {0,1}, {1,2,3} };編譯器出錯,突顯指定的要求除第一個維度外的所有維度的邊界。為了克服...
    程式設計 發佈於2024-11-17
  • 如何在 Sublime Text 2 中取得使用者輸入?
    如何在 Sublime Text 2 中取得使用者輸入?
    Sublime Text 2 中的使用者輸入使用者嘗試在Sublime Text 2 中輸入值時遇到困難,特別是在Python 中使用input() 或gets等函數時紅寶石。控制台不提示輸入,導致出現 EOFError 之類的錯誤。 此問題是由於 Sublime Text 2 缺乏控制台輸入的原生...
    程式設計 發佈於2024-11-17
  • 如何執行儲存在 MySQL 資料庫中的 PHP 程式碼?
    如何執行儲存在 MySQL 資料庫中的 PHP 程式碼?
    執行儲存在 MySQL 資料庫中的 PHP執行儲存在 MySQL 資料庫中的 PHP 為 Web 開發帶來了獨特的挑戰。要執行此操作,您可以使用 PHP 中內建的 eval() 函數。 eval() 函數eval() 函數計算給定的字串作為 PHP 程式碼。它執行解析後的程式碼,就像直接在腳本中編寫...
    程式設計 發佈於2024-11-17
  • 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-17
  • 如何處理 PHP 8.1 中的回傳類型衝突?
    如何處理 PHP 8.1 中的回傳類型衝突?
    參考:返回類型衝突與#[\ReturnTypeWillChange] 屬性上下文:在PHP 8.1 中,指定返回類型方法變得更加普遍,導致與現有實現發生衝突。 問題:當方法的返回類型從相容類型更改為不相容型別或未指定時,以下棄用出現通知:Deprecated: Return type of [Met...
    程式設計 發佈於2024-11-17
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-17
  • How to Correctly Transfer Files Over Sockets in Java?
    How to Correctly Transfer Files Over Sockets in Java?
    Java file transfer over sockets involves converting files into byte arrays, sending them via the socket, and converting them back into files at the receiving end. To address issues encountered during implementation, this article provides corrected server
    程式設計 發佈於2024-11-17
  • 為什麼要使用「enableReaderMode」 API 將 NDEF 記錄寫入 NFC 標籤?
    為什麼要使用「enableReaderMode」 API 將 NDEF 記錄寫入 NFC 標籤?
    如何將NDEF 記錄寫入NFC 標籤將NDEF 記錄寫入NFC 標籤需要使用enableReaderMode API,該API 提供卓越的效能和與基於意圖的系統相比的可靠性。透過處理讀寫過程而不是依賴系統的預設行為,寫入失敗和卡片損壞的風險顯著降低。 使用enableReaderMode API的主...
    程式設計 發佈於2024-11-17
  • 以下是一些適合您文章內容的問題式標題:

* Mac OS X 上的 MySQLdb:為什麼我收到「未載入函式庫:libmysqlclient.16.dylib」?
* 如何修復「庫未載入:l
    以下是一些適合您文章內容的問題式標題: * Mac OS X 上的 MySQLdb:為什麼我收到「未載入函式庫:libmysqlclient.16.dylib」? * 如何修復「庫未載入:l
    Python:MySQLdb 和「未載入函式庫:libmysqlclient.16.dylib」在嘗試開發Python/Django 應用程式時,您在Mac OS X 10.6 上安裝MySQL-python 時遇到問題。儘管成功安裝MySQL,但導入MySQLdb 失敗,並顯示錯誤訊息「未載入庫:...
    程式設計 發佈於2024-11-17
  • 發現漸進式 Web 應用程式為您的下一個專案帶來的最大優勢
    發現漸進式 Web 應用程式為您的下一個專案帶來的最大優勢
    Progressive online Apps, or PWAs, are quickly changing the online development landscape. PWAs are becoming the ideal way to connect mobile application...
    程式設計 發佈於2024-11-17
  • 現代 C++ 實作中的 std::list::size() 真的是 O(1) 嗎?
    現代 C++ 實作中的 std::list::size() 真的是 O(1) 嗎?
    在現代實作 std::list::size() 真的是 O(n) 嗎? 最近,一些開發人員建議std::list::size() 具有線性時間複雜度 (O(n))。但是,根據 C 標準,複雜性沒有定義,並且可能會根據實現而變化。 在 C 標準的早期版本 (C 03) 中,建議 size() 操作具有...
    程式設計 發佈於2024-11-17
  • 如何在 Heroku 上建立對 ClearDB MySQL 資料庫的遠端存取?
    如何在 Heroku 上建立對 ClearDB MySQL 資料庫的遠端存取?
    在 Heroku 上遠端存取 ClearDB MySQL 資料庫遠端查詢 ClearDB MySQL 資料庫可以透過 MySQL 查詢瀏覽器等工具來實現。要建立連接,您需要以下資訊:獲取資料庫憑證和連接詳細資訊:導航至Heroku 網站並選擇“My應用程式。” 選擇與ClearDB 資料庫關聯的應用...
    程式設計 發佈於2024-11-17

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

Copyright© 2022 湘ICP备2022001581号-3