博客
关于我
Oracle多表查询与数据更新
阅读量:793 次
发布时间:2023-02-25

本文共 2520 字,大约阅读时间需要 8 分钟。

多表查询入门:掌握SQL复杂查询技巧

在数据库开发中,多表查询是处理复杂数据关系的核心技能之一。本文将从基础到高级详细讲解多表查询的使用方法,帮助你在实际项目中高效处理数据。


2.1 多表查询

2.1.1 多表查询的基本语法

多表查询在SQL中用于从不同表中获取数据,通常用于处理复杂的数据关联关系。基本语法如下:

SELECT {DISTINCT} *|查询列1 别名1,查询列2 别名2FROM 表名称1 别名1,表名称2 别名2{WHERE 条件(s)}{ORDER BY 排序字段 ASC|DESC,排序字段 ASC|DESC}

例:同时查询emp和dept表

SELECT * FROM emp, dept;

返回了56条数据,emp表有14条记录,dept表有4条记录,56=14*4,这正是笛卡尔积的结果。


2.1.2 左、右连接

在实际项目中,笛卡尔积往往会导致冗余数据,需要通过左、右连接来去除冗余数据。

左连接(左外连接)

SELECT e.ename, e.deptno, d.dnameFROM emp eRIGHT JOIN dept dON e.deptno = d.deptno;

右连接(右外连接)

SELECT e.ename, e.deptno, d.dnameFROM emp eLEFT JOIN dept dON e.deptno = d.deptno(+);

左、右连接的区别在于连接符的位置,(+)表示外连接。


2.1.3 SQL:1999语法支持

SQL:1999语法提供了更灵活的表连接方式,包括:

  • 交叉连接(CROSS JOIN):产生笛卡尔积
  • 自然连接(NATURAL JOIN):自动匹配字段
  • 使用连接(USING):指定连接字段
  • ON子句:自定义连接条件
  • 左、右、外连接:处理冗余数据

2.2 组函数及分组统计

2.2.1 组函数

常用的组函数包括 COUNT(), MAX(), MIN(), AVG(), SUM() 等。

例:查询部门的总工资

SELECT deptno, SUM(sal) AS total_salFROM empWHERE deptno = 20;

2.2.2 分组统计

分组统计需要使用 GROUP BY 进行分组,语法格式如下:

SELECT {DISTINCT} *|列1 别名1, 列2 别名2FROM 表1 别名1, 表2 别名2{WHERE 条件(s)}{GROUP BY 分组条件}{ORDER BY 排序字段 ASC|DESC , 排序字段 ASC|DESC , …}

例:按部门分组,显示部门名称及员工数

SELECT COUNT(e.empno) AS emp_count, d.dnameFROM emp e, dept dWHERE e.deptno = d.deptnoGROUP BY d.dname;

使用HAVING完成分组筛选

WHERE 条件不足以完成分组筛选时,可以使用 HAVING

例:查询平均工资大于2000的部门编号和平均工资

SELECT deptno, avg(sal) AS avg_salFROM empGROUP BY deptnoHAVING avg(sal) > 2000;

2.3 子查询

子查询是将一个查询嵌入另一个查询中,常用于复杂的数据筛选。

子查询类型

  • 单列子查询:返回一个字段的结果。
  • 单行子查询:返回多个字段的结果。
  • 多行子查询:返回多条记录的结果。
  • 例:查询工资比7654高的所有雇员信息

    SELECT * FROM empWHERE sal > (SELECT sal FROM emp WHERE empno = 7654);

    子查询中的IN操作符

    通过 IN 运算符可以将子查询的结果限定在特定范围内。

    例:查询部门名称中包含’S’的部门员工总工资

    SELECT d.dname, SUM(e.sal) AS total_salFROM dept d, emp eWHERE d.dname LIKE '%S%'GROUP BY d.dname;

    2.4 数据库更新操作

    2.4.1 添加数据

    -- 使用精确写法INSERT INTO myemp (empno, ename, job, hiredate, sal, deptno)VALUES (7899, '张三', '清洁工', '14-2月-1995', 500, 40);-- 使用简略写法INSERT INTO myemp VALUES (7899, '张三', '清洁工', '14-2月-1995', 500, 40);

    2.4.2 修改数据

    -- 修改所有记录UPDATE myemp SET comm = 1000;-- 修改指定条件UPDATE myemp SET sal = 7000 WHERE empno = 7899;

    2.5 事务处理

    事务处理确保数据库操作的完整性,防止部分更新。

    示例:创建临时表并删除数据

    -- 创建临时表CREATE TABLE emp10 AS SELECT * FROM emp WHERE deptno = 10;-- 删除数据DELETE FROM emp10 WHERE empno = 7782;-- 查看结果SELECT * FROM emp10; -- 仍然存在7782记录

    2.6 查询练习

    1. 列出所有至少有一个员工的部门

    SELECT d.deptno, d.dnameFROM dept dJOIN (SELECT deptno FROM emp) on d.deptno = dn.deptno;

    2. 列出薪水高于“SMITH”的员工

    SELECT * FROM empWHERE sal > (SELECT sal FROM emp WHERE ename = 'SMITH');

    通过以上内容,你应该掌握了多表查询、组函数、子查询等SQL高级技巧的使用方法。实际项目中,建议结合实际需求进行灵活运用,逐步提升你的数据库开发能力。

    转载地址:http://xmpfk.baihongyu.com/

    你可能感兴趣的文章
    Openlayers:DMS-DD坐标形式互相转换
    查看>>
    openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
    查看>>
    OpenLDAP(2.4.3x)服务器搭建及配置说明
    查看>>
    OpenLDAP编译安装及配置
    查看>>
    Openmax IL (二)Android多媒体编解码Component
    查看>>
    OpenMCU(一):STM32F407 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>
    OpenMCU(二):GD32E23xx FreeRTOS移植
    查看>>
    OpenMCU(五):STM32F103时钟树初始化分析
    查看>>
    OpenMCU(四):STM32F103启动汇编代码分析
    查看>>
    OpenMetadata 命令执行漏洞复现(CVE-2024-28255)
    查看>>
    OpenMMLab | S4模型详解:应对长序列建模的有效方法
    查看>>
    OpenMMLab | 【全网首发】Llama 3 微调项目实践与教程(XTuner 版)
    查看>>
    OpenMMLab | 不是吧?这么好用的开源标注工具,竟然还有人不知道…
    查看>>
    OpenMMLab | 面向多样应用需求,书生·浦语2.5开源超轻量、高性能多种参数版本
    查看>>
    OpenMP 线程互斥锁
    查看>>
    OpenMV入门教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    OpenObserve云原生可观测平台本地Docker部署与远程访问实战教程
    查看>>
    openoffice使用总结001---版本匹配问题unknown document format for file: E:\apache-tomcat-8.5.23\webapps\ZcnsDms\
    查看>>