成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

第30期:JOIN簡化 - 消除關(guān)聯(lián)

企業(yè)動態(tài)
我們將等值JOIN分成三種情況來分別討論,分情況相當于加強了條件,我們可以充分利用每種情況下的特征。

【數(shù)據(jù)蔣堂】第30期:JOIN簡化 - 消除關(guān)聯(lián)

我們將等值JOIN分成三種情況來分別討論,分情況相當于加強了條件,我們可以充分利用每種情況下的特征。

1. 外鍵屬性化

先看個例子,設(shè)有如下兩個表:

外鍵屬性化

employee表和delpartment表的主鍵都是其中的id字段,employee表的department字段是指向department表的外鍵,department表的manager字段又是指向employee表的外鍵。這是很常規(guī)的表結(jié)構(gòu)設(shè)計。

現(xiàn)在我們想問一下:哪些美國籍員工有一個中國籍經(jīng)理?

用SQL寫出來是這樣的:

  1. SELECT A.* FROM employee A JOIN department B ON A.department=B.id JOIN employee C ON B.manager=C.id 
  2.     WHERE A.nationality=‘美國' AND C.nationality=‘中國' 

句子較長,由于employee表需要兩次參與JOIN,還需要為它起個別名加以區(qū)分。

我們換一種寫法:

  1. SELECT * FROM employee WHERE nationality='美國' AND department.manager.nationality='中國' 

當然,這不是標準的SQL語句了。

第二個句子中用紅色部分表示當前員工的“所屬部門的經(jīng)理的國籍”。我們把外鍵字段理解成一個對象,外鍵表的字段被理解為外鍵字段的屬性,department.manager即是”所屬部門的經(jīng)理“,而這個字段在department中仍然是個外鍵,那么它的外鍵表字段可以繼續(xù)理解為它的屬性,也就會有department.manager.nationality,即“所屬部門的經(jīng)理的國籍”。

這種的對象式理解方式,顯然比笛卡爾積過濾的理解方式要自然直觀得多。外鍵表JOIN時并不會涉及到兩個表的乘法,外鍵字段只是用于找到外鍵表中對應的那條記錄,完全不會涉及到笛卡爾積這種有乘法特性的運算。

我們前面約定,外鍵表JOIN時維表中關(guān)聯(lián)字段必須是主鍵,所以外鍵字段對應的維表記錄一定是***的,這樣deparment.manager.nationality對于employee表中每一條記錄都是***的,這就不會發(fā)生歧義。而如果不做這個約定,就可能發(fā)生多對多,department.manager.nationality無法明確定義。

事實上,這種對象式寫法在結(jié)構(gòu)化高級語言(如C,Java)中很常見,在這類語言中,數(shù)據(jù)就是按對象方式存儲的。employee表中的department字段取值根本就是一個對象,而不是編號。其實許多表的主鍵取值本身并沒有業(yè)務意義,僅僅是為了區(qū)分記錄,而外鍵字段也僅僅是為了找到外鍵表中的相應記錄,如果外鍵字段直接是對象,就不需要再通過編號來標識了。不過,SQL缺乏離散性,不能直接使用這種存儲機制,還要借助編號。

外鍵表關(guān)系中,事實表和維表是不對等的,只能基于事實表去找維表字段,而不會有倒過來的情況。

2. 同維表等同化

同維表的情況相對簡單,還是從例子開始,設(shè)有兩個表:

同維表等同化

兩個表的主鍵都是id,經(jīng)理也是員工,兩表共用同樣的員工編號,經(jīng)理會比普通員多一些屬性,另用一個經(jīng)理表來保存。

現(xiàn)在我們要統(tǒng)計所有員工(包括經(jīng)理)的總收入(加上津貼)。

用SQL寫出來還是會用到JOIN:

  1. SELECT employee.id, employee.name, employy.salary+manager.allowance FROM 
  2.     employyee LEFT JOIN manager ON employee.id=manager.id 

而對于兩個一對一的表,我們其實可以簡單地把它們看成一個表:

  1. SELECT id,name,salary+allowance FROM employee 

同樣地,根據(jù)我們的約定,同維表JOIN時兩個表都是按主鍵關(guān)聯(lián)的,相應記錄是***對應的,salary+allowance對employee表中每條記錄都是***可計算的,不會出現(xiàn)歧義。

同維表之間的關(guān)系是對等的,從任何一個表都可以引用到其它同維表的字段。

3. 主子表一體化

訂單及訂單明細是典型的主子表:

主子表一體化

Orders表的主鍵是id,OrderDetail表中的主鍵是(id,no),前者的主鍵是后者的一部分。

現(xiàn)在我們想計算每張訂單的總金額。

直接用SQL寫出來會是這樣:

  1. SELECT Orders.id, Orders.customer, SUM(OrderDetail.price) 
  2.     FROM Orders JOIN OrderDetail ON Orders.id=OrderDetail.id 
  3.         GROUP BY Orders.id, Orders.customer 

要完成這個運算,不僅要用到JOIN,還需要做一次GROUP BY,否則選出來的記錄數(shù)太多。

如果我們把子表中與主表相關(guān)的記錄看成主表的一個字段,那么這個問題也可以不再使用JOIN以及GROUP BY:

  1. SELECT id, customer, OrderDetail.SUM(price) FROM Orders 

與普通字段不同,OrderDetail被看成Orders表的字段時,其取值將是一個集合,因為兩個表是一對多的關(guān)系。所以要在這里使用聚合運算把集合值計算成單值。

這樣看待數(shù)據(jù)關(guān)聯(lián),不僅理解書寫更為簡單,而且不容易出錯。

假如Orders表還有一個子表用于記錄回款情況:

假如Orders表還有一個子表用于記錄回款情況

我們現(xiàn)在想知道那些訂單還在欠錢,也就是累計回款金額小于訂單總金額的訂單。

簡單地把這三個表JOIN起來是不對的,OrderDetail和OrderPayment會發(fā)生多對多的關(guān)系,這就錯了(回憶上一篇中多對多大概率錯誤的說法)。這兩個子表要分別先做GROUP,再一起與Orders表JOIN起來才能得到正確結(jié)果,寫出來較為繁瑣。

而如果我們把子表看成主表的集合字段,那就很簡單了:

  1. SELECT id,customer,OrderDetail.SUM(price) x, OrderPayment.SUM(amount) y FROM Orders WHERE x>

這種寫法就不容易發(fā)生多對多的錯誤。

主子表關(guān)系是不對等的,不過兩個方向的引用都有意義,上面談了從主表引用子表的情況,從子表引用主表則和外鍵表類似。

我們改變對JOIN運算的看法,摒棄笛卡爾積的思路,把多表關(guān)聯(lián)運算看成是稍復雜些的單表運算。這樣,我們相當于從最常見的等值JOIN運算中基本消除了關(guān)聯(lián),甚至在語法中取消了JOIN關(guān)鍵字,書寫和理解都要簡單很多。

責任編輯:趙寧寧 來源: 51CTO專欄
相關(guān)推薦

2017-12-10 22:42:50

JOINSQL運算

2017-12-12 22:48:21

JOIN維度運算

2017-11-08 06:18:43

JOINSQL運算

2017-12-26 15:33:24

JOINSQL運算

2018-01-01 23:28:37

JOIN維度數(shù)據(jù)分析

2018-01-10 15:25:43

JOIN維度SQL

2018-01-10 15:19:59

JOIN維度SQL

2017-12-10 22:48:53

JOIN運算外鍵

2017-12-12 22:58:57

JOIN外鍵運算

2020-11-10 08:54:55

Lombok

2021-12-21 10:35:49

技術(shù)資訊

2014-09-22 11:17:03

IT技術(shù)周刊

2016-07-22 23:07:24

智能工廠智能制造V課堂

2010-05-18 14:14:03

MySQL關(guān)聯(lián)left

2013-01-21 13:41:59

IBMdW

2017-10-09 22:33:56

SQL等值分組有序分組

2020-03-16 13:37:43

網(wǎng)絡安全網(wǎng)絡安全技術(shù)周刊

2017-09-05 22:34:24

遍歷SQL運算

2017-10-18 22:34:33

SQL等值分組有序分組

2018-01-18 20:47:18

CPU數(shù)據(jù)線程
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 小早川怜子xxxxaⅴ在线 | 中文字幕在线观看一区 | 国产精品欧美一区喷水 | 国产japanhdxxxx麻豆 | 免费国产精品久久久久久 | 久久久精品影院 | 情侣酒店偷拍一区二区在线播放 | 亚洲精品视频在线 | 精品国产91亚洲一区二区三区www | www.色综合| 噜噜噜噜狠狠狠7777视频 | 91精品国产综合久久久密闭 | 中文字幕在线二区 | 色狠狠桃花综合 | 91精品国产91久久久久久吃药 | 欧美日韩国产精品一区 | 国产日韩精品一区二区三区 | 久久久久国产 | 免费观看一级特黄欧美大片 | h片在线观看免费 | 亚洲毛片在线观看 | 欧美性乱 | 99久久国产综合精品麻豆 | 欧洲一区二区三区 | 国产精品明星裸体写真集 | 日韩一区和二区 | 中文字幕视频在线看5 | 三极网站 | 午夜丰满寂寞少妇精品 | 国产区精品 | 国产视频导航 | 亚洲高清久久 | 国产你懂的在线观看 | 亚洲毛片在线观看 | 日韩欧美大片 | 国产十日韩十欧美 | 欧美色成人 | 国产成人免费视频网站视频社区 | 一区二区三区久久 | 99re在线| 九九久久精品 |