Oracle資料庫初級學習 2

来源:http://www.cnblogs.com/yuyufeng/archive/2016/04/19/5410405.html
-Advertisement-
Play Games

今天我們介紹Oracle資料庫中剩餘的查詢方法,今天的查詢方法會比昨天的更為複雜一些(PS:我也是個初學者,請見諒。。)。 一、分組函數 分組函數是為了區分同一個表中的不同數據而建立,其關鍵字為GROUP BY,其中可以包含任意數目的列。 舉例: SELECT DEPTNO.MAX(SAL)FROM ...


今天我們介紹Oracle資料庫中剩餘的查詢方法,今天的查詢方法會比昨天的更為複雜一些(PS:我也是個初學者,請見諒。。)。

一、分組函數

  分組函數是為了區分同一個表中的不同數據而建立,其關鍵字為GROUP BY,其中可以包含任意數目的列。

  舉例:

  SELECT DEPTNO.MAX(SAL)FROM EMP GROUP BY DEPTNO;

  特別註意一旦用GROUP 分組後,前後的數值要保持一致,也就是說GROUP BY 是以DEPTNO為依據進行分組的話,SELECT 後面也必須有DEPTNO。

  同時,組函數例外。也就是說SELECT後面可以跟任意的組函數。

  還記得我們的組函數有哪些嗎?

  •avg()à返回某列的平均值   •min()à返回某列的最小值   •max()à返回某列的最大值   •sum()à返回某列值的和   •count()à返回某列的行數      下麵是一些具體實例。   SELECT DEPTNO.SAL FROM EMP GROUP BY DEPTNO,SAL;(錯誤,這樣進行分組將毫無意義,DEPTNO和SAL之間沒有任何練習)


  SELECT DEPTNO,MIN(SAL) FROM EMP GROUP BY DEPTNO;

  SELECT COMM,COUNT(*) FROM EMP GROUP BY COMM ORDER BY COMM;

  SELECT DEPTNO,AVG(SAL)FROM EMP GROUP BY DEPTNO ORDER BY AVG(SAL);

  

  

  

 

  特別註意:GROUP BY  子句必須出現在where子句之後,order by 子句之前,如果GROUP BY 之後還需要進行篩選,則採用關鍵字 HAVING。

   也就是說,SELECT 語句可以寫成  SELECT* FROM * WHERE* GROUP BY * HAVING* ORDER BY;

    程式的具體執行順序為  FROM WHERE GROUP BY HAVING SELECT ORDER BY

     同時考慮到程式的優化,能用WHERE過濾的數據堅決不用HAVING。

 

---分別統計30部門中每個JOB的最高薪資,並按照JOB排列。

SELECT JOB,MAX(SAL) FROM EMP WHERE DEPTNO=30 GROUP BY JOB ORDER BY JOB;

---查詢每個部門,每種工作的平均薪資

SELECT DEPTNO,JOB,AVG(SAL) FROM EMP GROUP BY DEPTNO,JOB ORDER BY DEPTNO;

--先執行WHERE 再執行GROUP

---查詢名字中有A的員工,每個部門 每種工作的平均薪資,並且平均薪資大於1500

SELECT DEPTNO,JOB,AVG(SAL) FROM EMP WHERE ENAME LIKE '%A%'GROUP BY DEPTNO,JOB HAVING AVG(SAL)>1500;

 

二、多表關聯查詢

  目前主流的SQL語句中分為SQL92和SQL99,我們先介紹SQL 92的相關內容。

  

  /*
  SQL92多表關聯查詢
  等值關聯
  非等值關聯
  外連接
  自連接

  */

  -------等值關聯

  

  SELECT * FROM EMP;
  SELECT * FROM DEPT;
  SELECT * FROM EMP,DEPT;
  SELECT * FROM EMP,DEPT WHERE EMP.DEPTNO = DEPT.DEPTNO;
  SELECT EMP.ENAME,EMP.DEPTNO,DEPT.DNAME FROM EMP,DEPT WHERE EMP.DEPTNO = DEPT.DEPTNO;
  SELECT E.ENAME,E.DEPTNO,D.DNAME,D.LOC FROM EMP E,DEPT D WHERE E.DEPTNO = D.DEPTNO;

 

  SELECT E.ENAME,D.LOC FROM EMP E,DEPT D
  WHERE E.DEPTNO = D.DEPTNO
  AND E.ENAME LIKE '%A%'
  AND D.DEPTNO IN(10,30);

 

  ------非等值關聯

  

  SELECT E.ENAME,E.SAL,S.GRADE FROM EMP E,SALGRADE S
  WHERE E.SAL BETWEEN S.LOSAL AND S.HISAL;

  


  為了連接N張表,至少需要N-1個條件。

 

  


  在做等值關聯的時候可能會因為兩表沒有共同的條件導致部分數據丟失,這是就要用到外連接
  ---外連接就是為瞭解決一張表中有數據,另一張表中沒有數據

  在SQL 92中,外連接分為左外連接和右外連接。

  SELECT * FROM EMP E,DEPT D
  WHERE E.DEPTNO=D.DEPTNO(+);

  此為左外連接,可顯示EMP中有,但DEPT表中無的數據

 

  SELECT * FROM EMP E,DEPT D
  WHERE E.DEPTNO(+)=D.DEPTNO;

  此為右外連接,可顯示EMP中無,DEPT中有的數據

  如果還不好記憶的話,可以記下麵的一句話。


  要顯示誰,就在對方後面加一個加號。

   看看下圖中有啥不同?

   

 

 

----自連接就是為瞭解決兩個要匹配的列都在一張表上面

SELECT E.ENAME,M.ENAME FROM EMP E,EMP M
WHERE E.MGR=M.EMPNO;

 

  99語法
    笛卡爾積
    等值連接
    自然:會將名字,類型相同的類自動做等值連接
        簡便
        有可能存在隱患(表的結構有可能被修改)
    欄位
      USING
    非等值連接
      ON
    外連接
      左外
      右外
      全外

  


SELECET * FROM EMP E,DEPT D;(92式)

SELECT * FROM EMP E CROSS JOIN DEPT D;(99式)

用CROSS JOIN 代替 ,

 

SELECT* FROM EMP E,DEPT D WHERE E.DEPTNO=D.DEPTNO;(92式)

SELECT* FROM EMP E NATURAL JOIN DEPT D;(99式)

NATURAL JOIN 又成為自然連接,會將名字,類型相同的類自動做等值連接,缺點是有可能存在隱患(表的結構有可能被修改)

所以,我們經常可以採用下麵一種方式

 


SELECT DEPTNO E.ENAME,D.DNAME FROM EMP E JOIN DEPT D USING(DEPTNO);(99式)(自動用DEPTNO做關聯,並且不能加限定詞,就是不能加E.或者D)

SLEECT* FROM EMP E, DEPT D WHERE E.DEPTNO=D.D.DEPTNO;(92式)

 

 

SELECT * FROM EMP E,SALGRADE S WHERE E.SAL BETWEEN S.LOSAL AND S.HISAL;


SELECT * FROM EMP E JOIN SALGRADE S ON ( E.SAL BETWEEN S.LOSAL AND S.HISAL);
(關鍵字JOIN ON代替了BETWEEN)

 

------外連接

---左外
SELECT * FROM EMP E,DEPT D
WHERE E.DEPTNO=D.DEPTNO(+);

SELECT * FROM EMP E LEFT OUTER JOIN DEPT D USING(DEPTNO);
(關鍵字 OUTJOIN USING)

---右外
SELECT * FROM EMP E,DEPT D
WHERE E.DEPTNO(+)=D.DEPTNO;

SELECT * FROM EMP E RIGHT OUTER JOIN DEPT D USING(DEPTNO);
(關鍵字 OUTER JOIN USING)

---全外 99特點,92沒有

SELECT * FROM EMP E FULL OUTER JOIN DEPT D USING(DEPTNO);

 

---自連接

SELECT E.ENAME,M.ENAME FROM EMP E JOIN EMP M ON(E.MGR = M.EMPNO);(99式)
(關鍵字 JOIN ON)代替了,where


SELECT E.ENAME,M.ENAME FROM EMP E,EMP M
WHERE E.MGR=M.EMPNO;(92式)

 

/*

子查詢
單行子查詢 返回一行
多行子查詢

只能運用三個運算符 IN SOME ALL

將查詢的結果抽象成一張表
*/

SELECT MAX(SAL) FROM EMP;
SELECT ENAME FROM EMP WHERE SAL=(SELECT MAX(SAL) FROM EMP);
理解子查詢的關鍵在於把子查詢當作一張表來看待。外層的語句可以把內嵌的子查詢返回的結果當成一張表使用。
子查詢要用括弧括起來
將子查詢放在比較運算符的右邊(增強可讀性)

SELECT ENAME FROM EMP WHERE SAL>=(SELECT AVG(SAL) FROM EMP);

SELECT * FROM EMP WHERE DEPTNO = 30;

SELECT * FROM EMP WHERE DEPTNO <> 30 AND SAL IN(SELECT SAL FROM EMP WHERE DEPTNO = 30);

SELECT * FROM EMP WHERE DEPTNO <> 30 AND >=SAL SOME(SELECT SAL FROM EMP WHERE DEPTNO = 30);

SELECT * FROM EMP WHERE DEPTNO <> 30 AND SAL>= ALL(SELECT SAL FROM EMP WHERE DEPTNO=30);

some 只要大於最小的選項
ALL 則要大於最大的


SELECT * FROM EMP WHERE SAL>= ALL(SELECT SAL FROM EMP WHERE DEPTNO=20)AND DEPTNO=20;(最大)

SELECT * FROM EMP WHERE SAL>= some(SELECT SAL FROM EMP WHERE DEPTNO=20)AND DEPTNO=20;(最小)


SELECT DEPTNO,AVG(SAL) FROM EMP WHERE DEPTNO IS NOT NULL GROUP BY DEPTNO;

SELECT DA.DEPTNO,S.GRADE FROM SALGRADE S(
SELECT DEPTNO,AVG(SAL) FROM EMP WHERE DEPTNO IS NOT NULL GROUP BY DEPTNO) DA
WHERE DA.AVGSAL BETWEEN S. LOSAL AND S. HISAL;

 

 

 

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

-Advertisement-
Play Games
更多相關文章
  • oracle客戶端導出dmp文件 備忘: 一直很少用導出dmp文件的,因為導出SQL已經夠用了,今天花了將近1個半小時,導出了一個13.2G的sql文件,記事本、editplus都無法打開,然後在plsql中導入,報錯(如圖)。 意味著一個半小時白費了。沒辦法只有使用exp導出了。 於是找到一個ba ...
  • GUID(Global unique identifier)全局唯一標識符,它是由網卡上的標識數字(每個網卡都有唯一的標識號)以及 CPU 時鐘的唯一數字生成的的一個 16 位元組的二進位值。 GUID 的格式為“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中每個 x ...
  • 我們以MySQL中常用的hint來進行詳細的解析,如果你是經常使用Oracle的朋友可能知道,Oracle的hincvt功能種類很多,對於優化sql語句提供了很多方法。 同樣,在MySQL里,也有類似的hint功能。下麵介紹一些常用的。 強制索引 MySQL FORCE INDEX 以上的SQL語句 ...
  • (1) 選擇最有效率的表名順序(只在基於規則的優化器中有效):ORACLE的解析器按照 從右到左的順序處理FROM子句中的表名,FROM子句中寫在最後的表(基礎表 driving table)將被最先處理,在FROM子句中包含多個表的情況下,你必須選擇記錄條數最少的表作為基礎表。如果有3個以上的表連 ...
  • 有時候啊,當我們存放在資料庫裡面的數據,需要明文存放,但是對於前臺查詢出來的,又不太希望明文放出去的時候(比方說客戶的手機啊,郵箱啊)之類有點敏感的信息,之前通常是保存個明文,然後在前臺展現的時候再特殊處理一下,然後就ok了。 而現在呢,在2016提供了data mask的功能,可以遮掩對應列的一些 ...
  • 上一篇說了一下openjson 的一些使用方法,這次再說一下在2016裡面的查詢取值,當然就是 json_query 和 json_value 這2兄弟了 首先 可以看到,對於json_value 來說,如果說取到的屬性並不能直接解析成int,string,bool 這3種類型(那就是說 array ...
  • 引言 SQL Server通過一些工具來監控數據,其中之一的方法就是動態管理管理視圖(DMV). 常規動態伺服器管理對象 dm_db_*:資料庫和資料庫對象 dm_exec_*:執行用戶代碼和關聯的連接 dm_os_*:記憶體、鎖定、時間安排 dm_tran_*:事務和隔離 dm_io_*:網路和磁碟 ...
  • 1、內聯接(典型的聯接運算,使用像 = 或 <> 之類的比較運算符)。包括相等聯接和自然聯接。 內聯接使用比較運算符根據每個表共有的列的值匹配兩個表中的行。例如,檢索 students和courses表中學生標識號相同的所有行。 2、外聯接。外聯接可以是左向外聯接、右向外聯接或完整外部聯接。 在 F ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...