Oracle 基础知识中集合函数与子查询的内容介绍

数据库 Oracle
以下的文章主要描述的是Oracle 基础知识中集合函数与子查询的相关项目的内容的介绍,以下就是文章的具体内容的相关介绍。

你对Oracle 基础知识中集合函数与子查询的相关项目是否有所了解?以及在这些项目的实际操作的应用,以下就是文章的相关内容的介绍,希望你浏览完以下的内容会有所获,以下就是文章的相关内容的介绍。

经常和group by一起使用

 1. 集合函数列表

AVG (DISTINCT | ALL | N) 取平均值

COUNT (DISTINCT | ALL | N | expr | * ) 统计数量

MAX (DISTINCT | ALL | N) 取最大值

MIN (DISTINCT | ALL | N) 取最小值

SUM (DISTINCT | ALL | N) 取合计值

9

J2EE @ zxw

STDDEV (DISTINCT | ALL | N) 取偏差值,如果组里选择的内容都相同,结果为0

VARIANCE (DISTINCT | ALL | N) 取平方偏差值

2. 使用集合函数的语法

SELECT column, group_function FROM table

WHERE condition GROUP BY group_by_expression

HAVING group_condition ORDER BY column;

3. 使用count时的注意事项

SELECT COUNT(*) FROM table;

SELECT COUNT(常量) FROM table;

都是统计表中记录数量,如果没有PK后者要好一些

SELECT COUNT(all 字段名) FROM table;

SELECT COUNT(字段名) FROM table;

不会统计为NULL的字段的数量

SUM,AVG时都会忽略为NULL的字段

4. 用group by时的限制条件

SELECT字段名不能随意, 要包含在GROUP BY的字段里

GROUP BY后ORDER BY时不能用位置符号和别名

限制GROUP BY的显示结果, 用HAVING条件

5. 例子

SQL> select title,sum(salary) payroll from s_emp

where title like 'VP%' group by title

having sum(salary)>5000 order by sum(salary) desc;

Oracle 基础知识中集合函数中找出某表里字段重复的记录数, 并显示

SQL> select (duplicate field names) from table_name

group by (list out fields) having count(*)>1;

6. 判断题(T/F)

(1) Group functions include nulls in calculations [F]

(2) Using the having clause to exclude rows from a group calculation [F]

解释:

Group function 都是忽略NULL值的 如果您要计算NULL值, 用NVL函数

Where语句在Group By前把结果集排除在外Having语句在Group By后把结果集排除在外

子查询

1. 查询语句可以嵌套

例如: SELECT …… FROM (SELECT …… FROM表名1, [表名2, ……] WHERE 条件) WHERE 条件2;

2. 何处可用子查询?

当查询条件是不确定的条件时

DML(insert, update,delete)语句里也可用子查询

HAVING里也可用子查询

3. 两个查询语句的结果可以做集合操作

例如:

并集UNION(去掉重复记录)

并集UNION ALL(不去掉重复记录)

10

J2EE @ zxw

差集MINUS,

交集INTERSECT

4. 子查询的注意事项

先执行括号里面的SQL语句,一层层到外面

内部查询只执行一次

如果里层的结果集返回多个,不能用= > < >= <=等比较符要用IN.

5. 子查询的例子(1)

SQL> select title,avg(salary) from s_emp

group by title Having avg(salary) =

(select min(avg(salary)) from s_emp

group by title);

找到最低平均工资的职位名称和工资

子查询的例子(2)

子查询可以用父查询里的表名

这条SQL语句是对的:

SQL>select cty_name from city where st_code in

(select st_code from state where st_name='TENNESSEE' and

city.cnt_code=state.cnt_code);

说明:父查询调用子查询只执行一次.

6.取出结果集的80 到100的SQL语句

ORACLE处理每个结果集只有一个ROWNUM字段标明它的逻辑位置,

并且只能 用ROWNUM<100, 不能用ROWNUM>80。

以下是经过分析后较好的两种ORACLE取得结果集80到100间的SQL语句

( ID是唯一关键字的字段名 )

语句写法:

SQL>select * from (

( select rownum as numrow, c.* from (

select [field_name,...] from table_name where 条件1 order by 条件2) c)

where numrow > 80 and numrow <= 100 )

order by 条件3;

以上的相关内容就是对Oracle 基础知识中集合函数的介绍,望你能有所收获。

【编辑推荐】

  1. Oracle函数to_char转化成小数点的位数
  2. Oracle to_char()函数具有强大的功能
  3. Oracle数据库中怎样选择合适索引类型
  4. Oracle数据类型转换的实际应用方案
  5. Oracle 10g环境的搭建手册
责任编辑:佚名 来源: 博客园
相关推荐

2022-03-30 08:37:32

Python函数编程自定义函数

2011-11-04 17:26:12

2010-04-15 13:19:29

Oracle架构

2011-08-29 18:43:45

MDX多维查询表达式

2009-09-14 14:49:12

LINQ查询基础知识

2009-08-11 15:17:12

C#基础知识

2009-08-13 15:40:28

C#基础知识

2009-11-05 09:51:14

WCF基础

2015-07-17 16:49:13

OpenStack开源云平台云计算

2010-05-25 14:50:25

MySQL 数据库

2010-04-22 11:32:57

Lvs负载均衡

2011-07-22 09:43:37

java

2011-07-21 17:45:02

java

2011-07-21 17:18:52

java

2011-07-21 17:33:27

JAVA

2011-07-22 10:02:07

java

2011-07-22 10:38:04

java

2011-02-25 09:37:35

2011-07-14 23:34:56

SEO

2021-03-13 10:14:59

Python定义函数Python基础
点赞
收藏

51CTO技术栈公众号