玩轉GaussDB 中的SET操作符

来源:https://www.cnblogs.com/huaweiyun/archive/2023/03/02/17171795.html
-Advertisement-
Play Games

摘要:關係資料庫中提供了一個關於集合的運算符SET操作符,其中包括以下操作:UNION/UNION ALL 並集、INTERSECT 交集、MINUS 差集。 本文分享自華為雲社區《GaussDB 中的SET操作符 (UNION, INTERSECT, MINUS)【玩轉PB級數倉GaussDB(D ...


摘要:關係資料庫中提供了一個關於集合的運算符SET操作符,其中包括以下操作:UNION/UNION ALL 並集、INTERSECT 交集、MINUS 差集。

本文分享自華為雲社區《GaussDB 中的SET操作符 (UNION, INTERSECT, MINUS)【玩轉PB級數倉GaussDB(DWS)】》,作者:林欣。

SET操作符有哪些

關係資料庫中提供了一個關於集合的運算符SET操作符,其中包括以下操作:

  • UNION/UNION ALL 並集
  • INTERSECT 交集
  • MINUS 差集

操作符講解

UNION

合併兩個查詢結果集,隱式DINSTINCT,刪除重覆行(即取集合併集)

–合併兩個提取表/派生表(derived table), 返回結果為:[a,b,c,d,e]

SELECT FC FROM (VALUES(‘a’),(‘b’),(‘c’),(‘e’)) Table1 (FC)
UNION
SELECT FC FROM (VALUES(‘a’),(‘b’),(‘c’),(‘d’)) Table2 (FC)

使用COUNT函數統計其個數,可以發現其結果總共只有5行

SELECT COUNT(1) FROM(
SELECT FC FROM (VALUES(‘a’),(‘b’),(‘c’),(‘e’)) Table1 (FC)
UNION
SELECT FC FROM (VALUES(‘a’),(‘b’),(‘c’),(‘d’)) Table2 (FC)
)

UNION ALL

簡單合併兩個查詢結果集,不刪除重覆行

將 UNION 改為 UNION ALL 可以看到,重覆行也被統計進去了(結果行數由前面的5行變為8行)

SELECT COUNT(1) FROM(
SELECT FC FROM (VALUES('a'),('b'),('c'),('e')) Table1 (FC)
UNION ALL
SELECT FC FROM (VALUES('a'),('b'),('c'),('d')) Table2 (FC)
)

EXCEPT / MINUS

返回出現在第一個結果集但不出現在第二個結果集中的所有行(即兩集合相減)

–返回結果為:[e]

SELECT FC FROM (VALUES(‘a’),(‘b’),(‘c’),(‘e’)) Table1 (FC)
EXCEPT
SELECT FC FROM (VALUES(‘a’),(‘b’),(‘c’),(‘d’)) Table2 (FC)

INTERSECT

返回第一個查詢結果集和第二個查詢結果集共有的部分(即取集合交集)

–返回結果為:[a,b,c]

SELECT FC FROM (VALUES(‘a’),(‘b’),(‘c’),(‘e’)) Table1 (FC)
INTERSECT
SELECT FC FROM (VALUES(‘a’),(‘b’),(‘c’),(‘d’)) Table2 (FC)

集合運算的使用場景

1、使用UNION代替Where子句中的OR,查詢速度更快

2、使用EXCEPT和INTERSECT, 過濾出列表中不存在/存在於資料庫中的項

 

點擊關註,第一時間瞭解華為雲新鮮技術~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 本文通過簡單的幾個示例,以及對同一個Makefile進行幾個版本的迭代,幫助快速的理解變數和模式規則的使用。 1、回顧 在上一篇文章中,我們使用Makefile編譯fun.c和main.c這兩個文件,最終生成名為app的可執行文件。 fun.c的內容 #include <stdio.h> vo ...
  • 1.1 搭建harbor伺服器 [root@rocky8 ~]$ cat /data/scripts/install_harbor.sh #!/bin/bash DOCKER_VERSION="20.10.10" UBUNTU_DOCKER_VERSION="5:${DOCKER_VERSION}~ ...
  • 隨著互聯網的發展,linux系統越來越突顯了巨大的作用,很多互聯網公司,政府企業,只要用到伺服器的地方幾乎都能看到linux系統的身影,可以說服務是不是在linux系統跑的代表了企業的技術水平,而與linux最相關的工作崗位就是linux運維工程師,實施工程師,linux開發工程師,我作為一個工作多 ...
  • 資料庫系統概論—基礎篇(1) 一、緒論 1.資料庫系統概述 1.1資料庫四個基本概念 數據:描述事物的符號記錄 資料庫(DB):存放數據的倉庫 資料庫管理系統(DBMS):位於用戶與操作系統之間的一層數據管理軟體 資料庫系統(DBS):由資料庫,資料庫管理系統,應用程式和資料庫管理員組成 1.2數管 ...
  • 一、什麼是DBT dbt (data build tool)是一款流行的開源數據轉換工具,能夠通過 SQL 實現數據轉化,將命令轉化為表或者視圖,提升數據分析師的工作效率。dbt 主要功能在於轉換資料庫或數據倉庫中的數據,在 E(Extract)、L(Load)、T(Transform) 的流程中, ...
  • Redis主從複製 主機數據更新後根據配置和策略, 自動同步到備機的 master/slaver 機制,Master 以寫為主,Slave 以讀為主,主從複製節點間數據是全量的。 作用: 讀寫分離,性能擴展 容災快速恢復 上圖將主伺服器複製了3份從伺服器,主伺服器進行寫操作,從伺服器進行讀操作,讀寫 ...
  • 近日,作為首屆未來數商大會協辦單位之一,袋鼠雲承辦“首屆未來數商大會——業數融合創新論壇”,與參會嘉賓共同探討數據驅動企業業務增長提效的新思路。袋鼠雲聯合創始人、易知微CEO 寧海元發表主題演講《數智視融合,構建數字產業生態鏈,釋放數據價值》,並帶來了本次論壇的重頭戲,首發《數據治理行業實踐白皮書》 ...
  • 多表查詢(下) 一. 聯合查詢 聯合查詢:將多次查詢結果合併,形成新的查詢結果集 select {欄位列表} from {表A} ... union [all] select {欄位列表} from {表B} ...; union all 會顯示重覆的部分,union 會去重,重覆的部分只顯示一次。 ...
一周排行
    -Advertisement-
    Play Games
  • 1. 說明 /* Performs operations on System.String instances that contain file or directory path information. These operations are performed in a cross-pla ...
  • 視頻地址:【WebApi+Vue3從0到1搭建《許可權管理系統》系列視頻:搭建JWT系統鑒權-嗶哩嗶哩】 https://b23.tv/R6cOcDO qq群:801913255 一、在appsettings.json中設置鑒權屬性 /*jwt鑒權*/ "JwtSetting": { "Issuer" ...
  • 引言 集成測試可在包含應用支持基礎結構(如資料庫、文件系統和網路)的級別上確保應用組件功能正常。 ASP.NET Core 通過將單元測試框架與測試 Web 主機和記憶體中測試伺服器結合使用來支持集成測試。 簡介 集成測試與單元測試相比,能夠在更廣泛的級別上評估應用的組件,確認多個組件一起工作以生成預 ...
  • 在.NET Emit編程中,我們探討了運算操作指令的重要性和應用。這些指令包括各種數學運算、位操作和比較操作,能夠在動態生成的代碼中實現對數據的處理和操作。通過這些指令,開發人員可以靈活地進行算術運算、邏輯運算和比較操作,從而實現各種複雜的演算法和邏輯......本篇之後,將進入第七部分:實戰項目 ...
  • 前言 多表頭表格是一個常見的業務需求,然而WPF中卻沒有預設實現這個功能,得益於WPF強大的控制項模板設計,我們可以通過修改控制項模板的方式自己實現它。 一、需求分析 下圖為一個典型的統計表格,統計1-12月的數據。 此時我們有一個需求,需要將月份按季度劃分,以便能夠直觀地看到季度統計數據,以下為該需求 ...
  • 如何將 ASP.NET Core MVC 項目的視圖分離到另一個項目 在當下這個年代 SPA 已是主流,人們早已忘記了 MVC 以及 Razor 的故事。但是在某些場景下 SSR 還是有意想不到效果。比如某些靜態頁面,比如追求首屏載入速度的時候。最近在項目中回歸傳統效果還是不錯。 有的時候我們希望將 ...
  • System.AggregateException: 發生一個或多個錯誤。 > Microsoft.WebTools.Shared.Exceptions.WebToolsException: 生成失敗。檢查輸出視窗瞭解更多詳細信息。 內部異常堆棧跟蹤的結尾 > (內部異常 #0) Microsoft ...
  • 引言 在上一章節我們實戰了在Asp.Net Core中的項目實戰,這一章節講解一下如何測試Asp.Net Core的中間件。 TestServer 還記得我們在集成測試中提供的TestServer嗎? TestServer 是由 Microsoft.AspNetCore.TestHost 包提供的。 ...
  • 在發現結果為真的WHEN子句時,CASE表達式的真假值判斷會終止,剩餘的WHEN子句會被忽略: CASE WHEN col_1 IN ('a', 'b') THEN '第一' WHEN col_1 IN ('a') THEN '第二' ELSE '其他' END 註意: 統一各分支返回的數據類型. ...
  • 在C#編程世界中,語法的精妙之處往往體現在那些看似微小卻極具影響力的符號與結構之中。其中,“_ =” 這一組合突然出現還真不知道什麼意思。本文將深入剖析“_ =” 的含義、工作原理及其在實際編程中的廣泛應用,揭示其作為C#語法奇兵的重要角色。 一、下劃線 _:神秘的棄元符號 下劃線 _ 在C#中並非 ...