多行函数:(聚合函数/分组函数)

解释:多条数据进入,单条结果出来(多进单出)

1).max(obj):最大值

2).min(obj):最小值

3).sum(num):求和

4).avg(num):求平均值

5).count(obj):计数

【注意事项】:

1).max()和min()两个函数可以接受任何数据类型的实际参数

2).sum()和avg()两个函数只能接受number类型的数据

3).多行函数/聚合函数/分组函数满足自动忽略空值的特点(在某些情况下,我们不应该忽略空值...)

案例如下:

查询公司薪资最高的、最低的、工资总和以及平均值的信息?

select max(salary),min(salary),sum(salary),avg(salary)

from employees;

参看如下代码并思考:

select max(last_name),max(hire_date),min(last_name),min(hire_date)

from employees;

关于count()的使用:

需求如下:

查询公司有多少员工?

select count(employee_id),count(last_name),count(hire_date) from employees;

select count(1),count(2),count(0),count(107),count('*') from employees;

执行以上代码发现效果都是正确的,我们以后做计数操作的时候,我们都用count('*')来实现;

查看如下代码:

select count(department_id),count(commission_pct) from employees;

执行以上代码发现问题所在,只要是多行函数/聚合函数/分组函数满足自动忽略空值的特点

修改以上代码实现需要的效果:

select count(nvl(department_id,100)),count(nvl(commission_pct,1)) from employees;

思考:avg() = sum() / count()?

答:以上的等式成立

需求如下:

查询公司的平均奖金率?

select avg(commission_pct),sum(commission_pct) / count(commission_pct),

sum(commission_pct) / count(nvl(commission_pct,2)),

sum(commission_pct) / 107,

sum(commission_pct) / count(*)

from employees;

作业:

--1.显示系统时间(注:日期+时间)

select to_char(sysdate,'yyyy/mm/dd hh24:mi:ss') from dual;

--2.查询员工号,姓名,工资,以及工资提高百分之20%后的结果(new salary)

select employee_id,last_name,salary,salary * 1.2 "new salary" from employees;

--3.将员工的姓名按首字母排序,并写出姓名的长度(length)

select last_name,length(last_name) from employees order by last_name;

--4.查询各员工的姓名,并显示出各员工在公司工作的月份数(worked_month)。

select last_name,round(months_between(sysdate,hire_date),0) "worked_month" from employees;

--5.查询员工的姓名,以及在公司工作的月份数(worked_month),并按月份数降序排列

select last_name,round(months_between(sysdate,hire_date),0) "worked_month"

from employees

order by "worked_month" desc;

--方式一:

select last_name || ' earns $' || salary || ' monthly but wants $' || 3 * salary "Dream Salary" from employees;

--方式二:

select last_name || ' earns' || to_char(salary,'$99999') || ' monthly but wants' || to_char(3 * salary,'$99999') "Dream Salary" from employees;

select last_name "Last_name",job_id "Job_id",

decode(job_id,'AD_PRES','A',

'ST_MAN','B',

'IT_PROG','C',

'SA_REP','D',

'E') "Grade"

from employees

where job_id in('AD_PRES','ST_MAN','IT_PROG','SA_REP','ST_CLERK')

order by "Grade" desc;

select last_name "Last_name",job_id "Job_id",

case job_id when 'AD_PRES' then 'A'

when 'ST_MAN' then 'B'

when 'IT_PROG' then 'C'

when 'SA_REP' then 'D'

else 'E' end "Grade"

from employees

where job_id in('AD_PRES','ST_MAN','IT_PROG','SA_REP','ST_CLERK')

order by "Grade" desc;

返回目录

学习python第三天之多行函数的更多相关文章

  1. 学习Python的三种境界

    前言 王国维在<人间词话>中将读书分为了三种境界:"古今之成大事业.大学问者,必经过三种之境界:'昨夜西风凋碧树,独上高楼,望尽天涯路'.此第一境也.'衣带渐宽终不悔,为伊消得人 ...

  2. 学习python第三天

    变量的命名规范 1.只能有 字母 数字 及_组成 2.不能以数字开头 3.避免与系统关键词重名:重名不会报错,但系统的功能就被自定义的功能屏蔽掉了(严重不建议这样做) 4._开头的变量都有特出含义 5 ...

  3. 【Python】Java程序员学习Python(三)— 基础入门

    一闪一闪亮晶晶,满天都是小星星,挂在天上放光明,好像许多小眼睛.不要问我为什么喜欢这首歌,我不会告诉你是因为有人用口琴吹给我听. 一.Python学习文档与资料 一般来说文档的资料总是最权威,最全面的 ...

  4. 学习python第三天单行函数

    1.去重:distinct关键字 需求:查看公司一共有多少部门? select department_id from employees;此代码会查出107条记录,存在部门重复的问题! select ...

  5. 学习python第三天数据库day2

    day01回顾: 数据库: 定义:存储数据的仓库(database,简称db) 常用的数据库对象有哪些? 1).数据表(table) ***** 2).视图(view) 3).索引(index) 4) ...

  6. 系统学习python第三天学习笔记

    day02补充 运算符补充 in value = "我是中国人" # 判断'中国'是否在value所代指的字符串中. "中国"是否是value所代指的字符串的子 ...

  7. python第三周文件处理和函数-----下

    #默认参数的值是在一开始定义的时候就传给了函数, # 在后来的修改中不会被修改. #默认参数的值必须放到位置形参参数的最后面 #默认参数使用的场景是一个参数不经常变得场景,所以参数一般是不可变类型.字 ...

  8. python第三周:集合、函数、编码、文件

    1.集合: 集合的创建: list_1 = set([1,2,3,4,5]) list_2 = set([2,3,44,7,8]) 集合的特性:集合是无序的,集合可以去掉重复的元素 集合的操作:求交集 ...

  9. 读书分享全网学习资源大合集,推荐Python学习手册等三本书「01」

    0.前言 在此之前,我已经为准备学习python的小白同学们准备了轻量级但超无敌的python开发利器之visio studio code使用入门系列.详见 1.PYTHON开发利器之VS Code之 ...

随机推荐

  1. ubuntu上安装redis

    1.Redis简要介绍 访问Redis官方网站 https://redis.io/ 上面介绍到 ,redis是开源,BSD许可,高级的key-value存储系统,可以用来存储字符串,哈希结构,链表,集 ...

  2. css3 transform(变形)笔记

    Transform字面上就是变形,改变的意思.在CSS3中transform主要包括以下几种:旋转rotate.扭曲skew.缩放scale和移动translate以及矩阵变形matrix. 一.旋转 ...

  3. Resharper 使用帮助-自动生成文件头

    VS2012 安装完resharper 后,在resharper选项中选择 Code Editing – File Header Text . 输入自定义的文件头格式.如果需要在文件头外层添加regi ...

  4. 神奇的datetime和datetime,一毫秒引发的血案

    今天才发现C#的datetime和sqlserver的daetime是多么的不一样.首先最小和最大值不一样这是众所周知的,其实精度也是一大坑. 比如 DateTime.Today.AddMillise ...

  5. 【学习笔记】--- 老男孩学Python,day15 python内置函数大全,递归,二分法

    1. lamda匿匿名函数2. sorted()3. filter()4. map()5. 递归函数 一. lamda 匿名函数 为了了解决一些简单的需求⽽设计的⼀句话函数 语法: 函数名 = lam ...

  6. hibernate、java、数据库对应类型

    引自 https://my.oschina.net/heau/blog/498874 java.数据库对应类型 类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述     ...

  7. dynamics 365 AI 解决方案 —— 介绍

    Digital transformation has been reshaping our world and artificial intelligence (AI) is one of the n ...

  8. Linux命令行得到系统IP

    输入ifconfig得到 eth0 Link encap:Ethernet HWaddr :::2E:9A: inet addr:192.168.1.1 Bcast:192.168.1.255 Mas ...

  9. 4.使用bat调用可执行jar文件

    一.项目需求 1.maven工程 2.有properties配置文件. 3.有内部jar包 二.简单的是实现实例 1.项目文件放置 注意:如果是web工程,我们会将jar文件当到我们项目WEB-INF ...

  10. tomcat idea optinos

    -server -XX:PermSize=128M -XX:MaxPermSize=256m -Xms512m -Xmx1024m