Oracle 數據庫-分組函數總結

Oracle 分組函數

分組函數作用于一組數據,并對一組函數返回一個值。

組函數類型
avg,count,max,min,sum
可以對數值型數據使用avg和sum函數。

select avg(salary),min(salary),max(salary),sum(salary) from employees where job_id like '%REP%';

avg(平均值)和sum(合計)函數:
可以對任意數據類型的數據使用 min和 max函數(包括日期)。

select min(hire_date),max(hire_date) from employees

count(*)返回表中記錄總數,適用于任意數據類型。

select count(*) from employees where department_id = 50;

count (expr) 返回expr不為空的記錄總數。

select count (commission_pct) from employees where department_id = 50;

組函數忽略空值

select avg(commission_pct) from employees;
·
NVL函數使分組函數無法忽略空值

select avg(nvl(commission_pct,0)) from employees;

count (distinct expr)返回expr非空且不重復的記錄總數

select count(distinct department_id) from employees;

可以使用group by子句將表中的數據分成若干組,在select列表中所有未包含在組函數中的列都應該包含在 group by子句中。

select department_id,avg(salary) from employees group by department_id;

包含在 group by 子句中的列不必包含在select列表中:

select avg(salary) from employees group by department_id;

在group by 子句中包含多個列:

select department_id,job_id,sum(salary) from employees group by department_id,job_id;

非法使用組函數:所有包含于select列表中,而未包含于組函數中的列都
必須包含于 GROUP BY 子句中。
如下:
select department_id,count(last_name) from employees;

非法使用組函數
? 不能在where子句中使用組函數。
? 可以在having子句中使用組函數。

如下:
select department_id,avg(saslary) from employees where avg(salary)>8000 group by department_id;
過濾分組:having 子句

  1. 行已經被分組。
  2. 使用了組函數。
  3. 滿足having子句中條件的分組將被顯示。

select department_id,max(salary) from employees group by department_id having max(salary)>10000;

嵌套組函數

select max(avg(salary)) from employees group by department_id;

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/443388.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/443388.shtml
英文地址,請注明出處:http://en.pswp.cn/news/443388.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

在notepad++中配置java編譯環境

在notepad中配置java編譯環境 (1)首先,下載安裝了Notepad,在菜單欄那里找到Plugin Manager,有一些版本是沒有中文的,所有只有Plugin Manager,如果連Plugin Manager都沒有,你則需要去…

Java 基礎數據類型

Java 基礎數據類型 Java的兩大數據類型:基本數據類型、引用類型。 Java語言提供了八種基本數據類型。六種數字類型(四個整數型,兩個浮點型),一種字符類型,還有一種布爾型。 整形:byte&#xf…

Java獲取系統時間

Java獲取系統時間 Java獲取系統時間 在java 中,有很多種方法都可以獲取到系統的當前時間,但也需要到對應的類,不同的類自然有不同的方法。這里為大家介紹獲取系統當前時間的四種方式。 1. 通過Calendar類來獲取當前時間 需要引用…

Java單例模式的幾種實現方式

Java單例模式的幾種實現方式 在Java 中,單例類只能有一個實例,必須創建自己的唯一實例,單例類必須給所有其他對象提供這一實例。Java 單例模式有很多種實現方式,在這里給大家介紹單例模式其中的幾種。分別是餓漢式,懶…

Java 中抽象類與接口

Java 抽象類: 在面向對象的概念中,所有的對象都是通過類來描繪的,但是反過來,并不是所有的類都是用來描繪對象的,如果一個類中沒有包含足夠的信息來描繪一個具體的對象,這個類就是抽象類。 抽象類不能創建…

Java 中的進程與線程的實現

了解進程與線程: 進程: 當一個程序進入內存運行時,即變成一個進程。進程是處于運行過程 中的程序,并且具有一定的獨立功能,進程是系統進行資源分配和調度的一個獨立單 位一般而言,進程包含如下三個特征&…

Java集合工具類:Collections

Java提供了一個操作Set、List和Map等集合的工具類:Collections,該工具類里 提供了大量方法對集合元素進行排序、查詢和修改等操作,還提供了對集合對象實現同步控制等方法。 一、 排序操作 如下示例: public class CollectionsSor…

Java異常處理throws/throw

Java的異常被分為兩大類:Checked異常和Runtime異常(運行時異常)。 ? Runtime異常:所有的RuntimeException類及其子類的實例; ? Checked異常:不是RuntimeException類及其子類的異常實例。 只有Java語言提供…

JDBC 連接MYSQL數據庫

1. 加載驅動 Class.forName("com.mysql.jdbc.Driver");com.mysql.jdbc 包名 Driver 驅動名,驅動包需要引入進來 mysql com.mysql.jdbc.Driveroracle oracle.jdbc.driver.OracleDriversqlserver com.microsoft.sqlserver.jdbc.SQLServerDriver …

JSP 之輸出九九乘法表

JSP是一種建立在Servlet規范提供的功能之上的動態網頁技術,允許在網頁文件中嵌入java代碼和jsp標記。Java 服務器頁面 (Java Server Page ,JSP) 擴展名為 .jsp。 1.jsp的執行過程 Jsp文件在用戶第一次請求時,會被編譯成Servlet,然后由這個Se…

Java 重寫與重載

方法的重寫: 重寫是子類對父類的允許訪問的方法的實現過程進行重新編寫, 返回值和形參都不能改變。 重寫的好處在于子類可以根據需要,定義特定于自己的行為。 也就是說子類能夠根據需要實現父類的方法。 重寫方法不能拋出新的檢查異常或者比被重寫方法申…

Java新增

在實踐項目中我們有可能需要做到新增功能,新增一張表,或是新增多張表。這里我新增的是一張表。 這里主要描述DAO層與Servlet 層: DAO 層: public class UserDaoImpl implements UserDao {private Connection con null;private P…

JSP根據狀態動態改變數據表格按鈕

有時候在開發的過程中會遇到需要根據狀態ID 來動態改變數據表格的按鈕&#xff0c;下面我主要講述兩種表格根據ID改變按鈕的方式。 下面這種我是用EL 表達式獲取表格中的值&#xff1a; <table class"table table-striped table-bordered table-hover" id"s…

Java 模糊查詢

在學習Java 這門語言過程中&#xff0c;會遇到無數的知識點與錯誤&#xff0c;最重要的是我們能夠在茫茫的代碼中找到突破口&#xff0c;并用心去汲取精華。 在很多時候我們會用到模糊查詢&#xff0c;這里是我在編碼過程中用到的模糊查詢。 JSP &#xff1a; <input value…

Java刪除表

Java刪除表 這里頁面我用了layui 框架做刪除的&#xff0c;這里需要引入layui 的css 與js 插件&#xff0c;這里寫出主要的代碼。 Jsp &#xff1a; //監聽行工具事件table.on(tool(test), function(obj){var data obj.data; //獲得當前行數據var date1 data.classifyColum…

原始分頁

Jsp &#xff1a; <div style"float: right;">當前為${currentPage}頁&#xff0c;共有${totalRow}條數據&#xff0c;共${totalPage}頁 <select style"border-radius: 18px;" id"pageSize" name"pageSize" onchange"c…

根據銀行卡號判斷銀行卡是否正確與歸屬銀行

校驗過程&#xff1a; 1.從卡號的最后一位數字開始&#xff0c;逆向將奇數位&#xff08;1&#xff0c;3&#xff0c;5 等等相加&#xff09; 2.從卡號最后一位數字開始&#xff0c;逆向將偶數位數字&#xff0c;先乘以2&#xff0c;如果乘積為兩位數&#xff0c;將個位數字相加…

根據年月日判斷第多少天,星期幾

1. 根據年月日判斷第多少天 Scanner是SDK1.5新增的一個類,可使用該類創建一個對象。 Scanner scannernew Scanner(System.in);  然后scanner對象調用下列方法&#xff08;函數&#xff09;,讀取用戶在命令行輸入的各種數據類型   next.Byte(),nextDouble(),nextFloat,nextIn…

解決MySQLyog 導入數據庫文件沒有反應

之前我在MySQL 中新建了一個數據庫&#xff0c;名為“onlineclassroom” 的數據庫&#xff0c;但是在將外部的.sql 文件導入進來之后發現&#xff0c;數據庫沒有反應&#xff0c;也看不到表數據&#xff0c;以為是沒有刷新問題&#xff0c;但是刷新之后發現還是沒有這個就很奇怪…

解決myeclipse報錯500,MySQLyog報錯誤碼問題

在myeclipse 寫了一個登錄&#xff0c;但在我登錄的時候卻報了500的空指針&#xff0c;我檢查了自己的登錄代碼&#xff0c;發現沒有問題&#xff0c;這不應該啊&#xff0c;然后在網上也尋找了一些解決方案&#xff0c;發現好像并不適用&#xff0c;500空指針如下&#xff1a;…