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 基础知识中集合函数的介绍,望你能有所收获  。