以下的文章主要描述的是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 基础知识中调集函数的介绍,望你能有所收成。
【修改引荐】
- Oracle函数to_char转化成小数点的位数
- Oracle to_char()函数具有强壮的功用
- Oracle数据库中怎样挑选适宜索引类型
- Oracle数据类型转化的实践运用计划
- Oracle 10g环境的建立手册