Oracle数据库分组查询实战指南

需积分: 29 1 下载量 55 浏览量 更新于2024-08-15 收藏 1.47MB PPT 举报
"Oracle数据库实用教程,包括分组查询练习及数据库基础知识讲解" 在Oracle数据库中,分组查询是用于汇总数据并根据一个或多个列进行分组的关键操作。这通常涉及使用`GROUP BY`子句,它可以让我们计算每个组的聚合函数,如总和(SUM)、平均值(AVG)、最大值(MAX)和最小值(MIN)。以下是对描述中提到的三个练习的解答: 1) 从EMP表中返回部门编号和部门平均工资的SQL语句如下: ```sql SELECT department_id, AVG(salary) as avg_salary FROM EMP GROUP BY department_id; ``` 2) 返回部门编号和部门工资总和大于8000的SQL语句: ```sql SELECT department_id, SUM(salary) as total_salary FROM EMP GROUP BY department_id HAVING SUM(salary) > 8000; ``` 在这里,`HAVING`子句用于在聚合后过滤结果,因为它允许我们在聚合函数上设置条件。 3) 返回除部门10外,平均工资大于1500的部门编号和平均工资的SQL语句: ```sql SELECT department_id, AVG(salary) as avg_salary FROM EMP WHERE department_id != 10 GROUP BY department_id HAVING AVG(salary) > 1500; ``` 数据库是用于存储和管理数据的系统,随着技术的发展,数据管理经历了人工管理、文件系统和数据库系统三个阶段。在数据库系统阶段,数据独立性更高,通过数据库管理系统(DBMS)实现数据的定义、操作和管理。关系型数据库是其中最常见的一种,例如Oracle、DB2、Informix和Sybase,它们以表格形式组织数据,并通过关系模型关联不同表之间的数据。 在Oracle数据库中,表是数据的主要组织形式,包括表结构(DDL)和表内容(DML)。表结构涉及创建、修改、删除和截断操作,如`CREATE TABLE`、`ALTER TABLE`、`DROP TABLE`和`TRUNCATE TABLE`。表内容则涉及插入、更新和删除操作,如`INSERT`、`UPDATE`、`DELETE`,以及查询表结构和内容的命令,如`DESCRIBE`和`SELECT`。 此外,Oracle支持多种基本数据类型,如`CHAR`、`VARCHAR2`、`LONG`和`NUMBER`。`CHAR`和`VARCHAR2`用于存储字符数据,`NUMBER`可以存储数值数据,其中`NUMBER[(m[,n])]`的m表示总位数,n表示小数位数。例如,`NUMBER(5,2)`可以存储最多5位数字,其中2位是小数。 Oracle数据库还提供了丰富的功能和工具,如视图、索引、触发器、存储过程和函数,以满足复杂的数据管理和业务需求。通过掌握这些基础概念和操作,用户可以有效地管理、查询和分析数据库中的数据。