搜尋
首頁php教程PHP开发Oracle minus用法詳解及應用實例

Oracle minus用法

       「minus」直接翻譯為中文是「減」的意思,在Oracle中也是用來做減法操作的,只不過它不是傳統意義上對數字的減法,而是對查詢結果集的減法。 A minus B就意味著將結果集A去除結果集B中所包含的所有記錄後的結果,即在A中存在,而在B中不存在的記錄。其演算法跟Java中的Collection的removeAll()類似,即A minus B將只去除A跟B的交集部分,對於B中存在而A中不存在的記錄不會做任何操作,也不會拋出異常。

       Oracle的minus是按列進行比較的,所以A能夠minus B的前提條件是結果集A和結果集B需要有相同的列數,且相同列索引的列具有相同的資料類型。此外,Oracle會對minus後的結果集進行去重,也就是如果A中原本多筆相同的記錄數在進行A minus B後將會只剩下一筆對應的記錄,具體情況請看下面的範例。

        以下我們來看一個minus實際應用的範例,假設我們有一個使用者表t_user,其中有下列記錄資料:

Oracle minus用法详解及应用实例

 那麼:

inus(1)「userselect 5 id from t_user where id between 3 and 7」的結果將為:

Oracle minus用法详解及应用实例

(2)「select age,level_no from t_user where id

Oracle minus用法详解及应用实例

 看到這樣的結果,可能你會覺得有點奇怪,為何會是這樣呢?我們來分析一下。首先,「select age,level_no from t_user where id

Oracle minus用法详解及应用实例

 然後,「select age,level_no from t_user where level=3」的結果將會是這樣的:

Oracle minus用法详解及应用实例

然後,直接A minus B之後結果應當是:

Oracle minus用法详解及应用实例

       這個時候,我們可以看到結果集中存在重複的記錄,進行去重後就得到了上述的實際結果。其實這也很好理解,因為minus的作用就是找出在A中存在,而B中不存在的記錄。

       上述範例都是針對於單表的,很顯然,使用minus進行單表操作是不具備優勢的,其通常用於找出A表中的某些字段在B表中不存在對應記錄的情況。例如我們擁有另外一個表t_user2,其擁有和t_user表一樣的表結構,那麼如下語句可以找出除id外,在t_user表中存在,而在t_user2表中不存在的記錄。

select no,name,age,level_no from t_user minus select no,name,age,level_no from t_user2;

感謝閱讀,希望能幫助大家,謝謝大家對本站的支持!

更多Oracle minus用法詳解及應用實例相關文章請關注PHP中文網!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),