日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
創(chuàng)新互聯(lián)OceanBase教程:OceanBaseEXCEPT/MINUS

EXCEPT 算子用于對左右孩子算子輸出集合進(jìn)行差集運算,并進(jìn)行去重。

夏津網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),夏津網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為夏津上千余家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的夏津做網(wǎng)站的公司定做!

Oracle 模式下一般使用 MINUS 進(jìn)行差集運算,MySQL 模式下一般使用 EXCEPT 進(jìn)行差集運算。OceanBase 數(shù)據(jù)庫的 MySQL 模式不區(qū)分 EXCEPT 和 MINUS,兩者均可作為差集運算關(guān)鍵字使用。

OceanBase 數(shù)據(jù)庫支持的 EXCEPT 算子包括 MERGE EXCEPT DISTINCT 和 HASH EXCEPT DISTINCT。

MERGE EXCEPT DISTINCT

如下示例中,Q1 對兩個查詢使用 MINUS 進(jìn)行聯(lián)接, c1 有可用排序,0 號算子生成了 MERGE EXCEPT DISTINCT 進(jìn)行求取差集、去重,由于 c2 無可用排序,所以在 3 號算子上分配了 SORT 算子進(jìn)行排序。算子執(zhí)行時從左右孩子節(jié)點讀取有序輸入,利用有序輸入進(jìn)行 MERGE, 實現(xiàn)去重并得到差集結(jié)果。


obclient>CREATE TABLE t1(c1 INT PRIMARY KEY, c2 INT);
Query OK, 0 rows affected (0.12 sec)

obclient>INSERT INTO t1 VALUES(1,1);
Query OK, 1 rows affected (0.12 sec)

obclient>INSERT INTO t1 VALUES(2,2);
Query OK, 1 rows affected (0.12 sec)

Q1: 
obclient>EXPLAIN SELECT c1 FROM t1 MINUS SELECT c2 FROM t1\G;
*************************** 1. row ***************************
Query Plan:
==============================================
|ID|OPERATOR             |NAME|EST. ROWS|COST|
----------------------------------------------
|0 |MERGE EXCEPT DISTINCT|    |2        |77  |
|1 | TABLE SCAN          |T1  |2        |37  |
|2 | SORT                |    |2        |39  |
|3 |  TABLE SCAN         |T1  |2        |37  |
==============================================
Outputs & filters: 
-------------------------------------
  0 - output([MINUS(T1.C1, T1.C2)]), filter(nil)
  1 - output([T1.C1]), filter(nil), 
      access([T1.C1]), partitions(p0)
  2 - output([T1.C2]), filter(nil), sort_keys([T1.C2, ASC])
  3 - output([T1.C2]), filter(nil), 
      access([T1.C2]), partitions(p0)

上述示例中,執(zhí)行計劃展示中的 outputs & filters 詳細(xì)列出了 EXCEPT 算子的輸出信息如下:

信息名稱

含義

output

該算子的輸出表達(dá)式。

使用 EXCEPT/MINUS 聯(lián)接的兩孩子算子對應(yīng)輸出(Oracle 模式使用 MINUS,MySQL 模式使用 EXCEPT),表示差集運算輸出結(jié)果中的一列,括號內(nèi)部為左右孩子節(jié)點對應(yīng)此列的輸出列。

filter

該算子上的過濾條件。

由于示例中 EXCEPT 算子沒有設(shè)置 filter,所以為 nil。

HASH EXCEPT DISTINCT

如下示例中,Q2 對兩個查詢使用 MINUS 進(jìn)行聯(lián)接,不可利用排序,0 號算子使用 HASH EXCEPT DISTINCT 進(jìn)行求取差集、去重。算子執(zhí)行時先讀取左側(cè)孩子節(jié)點輸出建立哈希表并去重,再讀取右側(cè)孩子節(jié)點輸出利用哈希表求取差集并去重。


Q2: 
obclient>EXPLAIN SELECT c2 FROM t1 MINUS SELECT c2 FROM t1\G;
*************************** 1. row ***************************
Query Plan:
=============================================
|ID|OPERATOR            |NAME|EST. ROWS|COST|
---------------------------------------------
|0 |HASH EXCEPT DISTINCT|    |2        |77  |
|1 | TABLE SCAN         |T1  |2        |37  |
|2 | TABLE SCAN         |T1  |2        |37  |
=============================================
Outputs & filters: 
-------------------------------------
  0 - output([MINUS(T1.C2, T1.C2)]), filter(nil)
  1 - output([T1.C2]), filter(nil), 
      access([T1.C2]), partitions(p0)
  2 - output([T1.C2]), filter(nil), 
      access([T1.C2]), partitions(p0)

上述示例的執(zhí)行計劃展示中的 outputs & filters 詳細(xì)列出了 HASH EXCEPT DISTINCT 算子的輸出信息,字段的含義與 MERGE EXCEPT DISTINCT 算子相同。


網(wǎng)頁標(biāo)題:創(chuàng)新互聯(lián)OceanBase教程:OceanBaseEXCEPT/MINUS
標(biāo)題路徑:http://www.dlmjj.cn/article/dhdijdd.html