自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

搞定SQL!5個(gè)棘手SQL查詢的解決方法

數(shù)據(jù)庫 SQL Server
對(duì)于數(shù)據(jù)科學(xué)家來講,SQL(結(jié)構(gòu)化查詢語言)是其工具箱中比較重要的工具之一。掌握SQL不僅有助于你在面試中脫穎而出,而且通過解決復(fù)雜查詢達(dá)到對(duì)SQL的充分理解,還能在讓你許多競爭中保持領(lǐng)先地位。

 對(duì)于數(shù)據(jù)科學(xué)家來講,SQL(結(jié)構(gòu)化查詢語言)是其工具箱中比較重要的工具之一。掌握SQL不僅有助于你在面試中脫穎而出,而且通過解決復(fù)雜查詢達(dá)到對(duì)SQL的充分理解,還能在讓你許多競爭中保持領(lǐng)先地位。

[[344803]]

本文就將介紹5個(gè)有關(guān)SQL的棘手問題和其解決方法。注意,每個(gè)查詢都能以不同方式編寫。在參考本文解決方案之前,你可以先試著自己思考一下。

 

查詢1

下列表格由名字和職業(yè)兩列組成。需要查詢所有姓名,且使其后緊跟一個(gè)括號(hào),括住“職業(yè)”列中對(duì)應(yīng)的首字母。

 

搞定SQL!5個(gè)棘手SQL查詢的解決方法

 

  • 本文解決方案

 

  1. SELECT 
  2. CONCAT(Name, ’(‘, SUBSTR(Profession, 1, 1), ’)’) 
  3. FROM table

由于需要把名字和職業(yè)結(jié)合起來,可以使用CONCAT。而且因?yàn)槔ㄌ?hào)內(nèi)只需要一個(gè)字母,可以使用SUBSTR來傳遞列名、開始索引和結(jié)束索引。因?yàn)橹恍枰鬃帜福晕覀儗鬟f1,1(開始索引包括在內(nèi),結(jié)束索引不包括在內(nèi))。

 

查詢2

蒂娜需要從她創(chuàng)建的EMPLOYEES表中計(jì)算所有員工的平均工資,但結(jié)果顯示的平均值很低,這可能是鍵盤上的回零鍵失效了。她希望我們幫助找出錯(cuò)誤計(jì)算的平均值和實(shí)際平均值之間的差異。我們須編寫一個(gè)查找錯(cuò)誤的查詢(實(shí)際平均值-計(jì)算平均值)。

 

搞定SQL!5個(gè)棘手SQL查詢的解決方法

 

  • 本文解決方案

 

  1. SELECT 
  2. AVG(Salary) - AVG(REPLACE(Salary, 0, ’’)) 
  3. FROM table

需要注意,只有一個(gè)表包含了實(shí)際工資值。為了創(chuàng)建錯(cuò)誤場(chǎng)景,使用REPLACE替換0。接著傳遞列名、替換值以及用于替換REPLACE方法的值。然后,使用聚集函數(shù)AVG來求平均值的差。

 

查詢3

給定一個(gè)表,它是由節(jié)點(diǎn)和父節(jié)點(diǎn)兩列組成的二元搜索樹。需要編寫一個(gè)查詢,以返回按節(jié)點(diǎn)值進(jìn)行升序排序的節(jié)點(diǎn)類型。有3種類型:

 

  • 根(Root)——如果節(jié)點(diǎn)是根
  • 葉(Leaf)——如果節(jié)點(diǎn)是葉
  • 內(nèi)部(Inner)——如果節(jié)點(diǎn)既不是根也不是葉

 

搞定SQL!5個(gè)棘手SQL查詢的解決方法

 

 

 

  • 本文解決方案

經(jīng)過初步分析,可以得出結(jié)論:如果給定節(jié)點(diǎn)N的相應(yīng)P值為NULL(空),則它是根。而如果給定節(jié)點(diǎn)N存在于P列中,則它不是內(nèi)部節(jié)點(diǎn)?;诖讼敕ň帉懸粋€(gè)查詢。

 

  1. SELECT CASE 
  2.     WHEN P IS NULL THENCONCAT(N, ' Root'
  3.     WHEN N IN (SELECTDISTINCT P from BST) THEN CONCAT(N, ' Inner'
  4.     ELSE CONCAT(N, ' Leaf'
  5.     ENDFROM BSTORDER BY N asc

可使用CASE作為開關(guān)函數(shù)。正如前文提到的,如果對(duì)于給定節(jié)點(diǎn)N,P為空值,則N是根。因此,我們使用CONCAT來組合節(jié)點(diǎn)值和標(biāo)簽。

類似地,如果給定節(jié)點(diǎn)N存在于P列中,則它是內(nèi)部節(jié)點(diǎn)。為了獲得P列中的所有節(jié)點(diǎn),我們編寫了一個(gè)返回P列中所有不同節(jié)點(diǎn)的子查詢。由于要求按節(jié)點(diǎn)值升序?qū)敵鲞M(jìn)行排序,因此要使用ORDER BY子句。

 

查詢4

該事務(wù)表由transaction_id, user_id, transaction_date,product_id, and quantity(交易ID,用戶ID,交易日期,產(chǎn)品ID和數(shù)量)組成。需要查詢多天來購買產(chǎn)品的用戶數(shù)量(注意,給定用戶可以在一天內(nèi)購買多個(gè)產(chǎn)品)。

 

搞定SQL!5個(gè)棘手SQL查詢的解決方法

 

  • 本文解決方案

為了解決該查詢,不能直接計(jì)算user_id的出現(xiàn)次數(shù),由于給定用戶在一天中可以多次購買,user_id或許會(huì)有多次返回。因此,只有當(dāng)存在多個(gè)不同日期與給定的user_id相關(guān)聯(lián)時(shí),才意味著該用戶多天購買了產(chǎn)品。按照相同方法,進(jìn)行查詢編寫。(內(nèi)部查詢)

 

  1. SELECT COUNT(user_id) 
  2. FROM 
  3. (SELECT user_id 
  4.  FROM orders 
  5.  GROUP BY user_id 
  6.  HAVING COUNT(DISTINCT DATE(date))> 1 
  7. ) t1 

由于問題詢問的是user_id的數(shù)量,而不是user_id本身,因此在外部查詢中使用 COUNT 。

 

查詢5

給定一個(gè)訂閱表,其中包含每個(gè)用戶訂閱的開始和結(jié)束日期。需要編寫一個(gè)查詢,根據(jù)與其他用戶的日期重疊情況,為每個(gè)用戶返回true/false。例如,如果user1的訂閱周期與其他任何用戶重疊,則查詢必須為user1返回true。

 

搞定SQL!5個(gè)棘手SQL查詢的解決方法

 

  • 本文解決方案

經(jīng)過初步分析,我們可以知道必須將每項(xiàng)訂閱與其他訂閱進(jìn)行比較。將userA的開始和結(jié)束日期視為startA 和endA,類似地,userB也依此設(shè)為startB和endB。如果startA≤endB且endA≥startB,則可以說這兩個(gè)日期范圍重疊。我們來舉兩個(gè)例子,先比較一下U1和U3:

 

  1. startA = 2020–01–01 
  2. endA = 2020–01–31 
  3. startB = 2020–01–16 
  4. endB = 2020–01–26 

這里可以看出,startA(2020–01–01)小于endB(2020–01–26),那么同樣,endA(2020–01–31)大于 startB(2020–01–16),因此可以得出結(jié)論,日期重疊。類似地,如果比較U1和U4,上述條件就不成立,于是返回FALSE。

這里還必須確保不會(huì)將用戶與其自己的訂閱進(jìn)行比較。同時(shí)希望運(yùn)行一個(gè)左連接,能夠自行將用戶與滿足條件的其他用戶進(jìn)行匹配。現(xiàn)在,我們將創(chuàng)建同一表的兩個(gè)副本S1和S2。

 

  1. SELECT * 
  2. FROM subscriptions AS s1 
  3. LEFT JOIN subscriptions AS s2 
  4.     ON s1.user_id != s2.user_id 
  5.         AND s1.start_date <=s2.end_date 
  6.         AND s1.end_date >=s2.start_date 

給定條件連接,在日期之間存在重疊的情況下,對(duì)于S1中的每個(gè)user_id,應(yīng)該存在來自S2的user_id。

  • 輸出

 

搞定SQL!5個(gè)棘手SQL查詢的解決方法

 

可以看到,以防日期重疊,每個(gè)用戶都有一個(gè)對(duì)應(yīng)用戶。對(duì)于user1,有2行顯示其與2個(gè)用戶相匹配。對(duì)于用戶4,對(duì)應(yīng)的ID為空,表示他與其他任何用戶都不匹配?,F(xiàn)在,將其全部組合在一起,按照s1.user_ID字段進(jìn)行分組,并檢查s2.user_ID不為空的用戶的值是否為真。

  • 最終查詢

 

  1. SELECT 
  2.     s1.user_id    , (CASE WHEN s2.user_idIS NOT NULL THEN 1 ELSE 0 ENDAS overlap 
  3. FROM subscriptions AS s1 
  4. LEFT JOIN subscriptions AS s2 
  5.     ON s1.user_id != s2.user_id 
  6.         AND s1.start_date <=s2.end_date 
  7.         AND s1.end_date >=s2.start_date 
  8. GROUP BY s1.user_id 

使用 CASE子句根據(jù)給定用戶的s2.user_id值來標(biāo)記1和0。最終輸出如下:

 

 

搞定SQL!5個(gè)棘手SQL查詢的解決方法

 

 

 

責(zé)任編輯:華軒 來源: 讀芯術(shù)
相關(guān)推薦

2024-05-24 12:06:26

SQL數(shù)據(jù)庫

2025-04-07 07:20:35

SQL慢查詢性能

2010-10-19 10:25:29

SQL Server連

2013-01-05 13:49:00

2010-09-28 13:53:59

sql text字段

2010-10-19 12:22:02

SQL Server遠(yuǎn)

2010-09-03 11:05:59

SQL刪除

2010-11-10 13:42:32

SQL Server刪

2010-10-22 14:35:02

sql server系

2010-11-08 16:16:57

SQL Server遠(yuǎn)

2010-10-19 11:08:00

SQL Server安

2011-07-22 13:46:41

SQL Server MDAC

2020-03-16 08:13:58

SQL性能問題

2009-05-04 13:43:16

SQL Server置疑數(shù)據(jù)庫恢復(fù)

2011-08-01 09:25:32

SQL Server數(shù)

2010-10-21 09:43:15

2010-09-16 15:36:26

SQL Server2

2011-04-02 13:57:05

Sql Server

2010-10-13 17:22:12

MySQL查詢亂碼

2010-10-20 17:21:07

連接SQL Serve
點(diǎn)贊
收藏

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