IT评测·应用市场-qidao123.com技术社区

标题: MySQL基础:多表查询 [打印本页]

作者: 耶耶耶耶耶    时间: 2023-4-4 14:05
标题: MySQL基础:多表查询
MySQL基础:多表查询

多表关系

​        项目开发中,在进行数据库表结构设计时,会根据业务需求及模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各个表结构之间也存在着各种联系,基本上分为三种:

多表查询概述

例子:
  1. select * from emp,dept where emp.dept_id = dept.id;
复制代码
连接查询--内连接

内连接查询的是两张表交集的部分。
  1. SELECT 字段列表 FROM 表1,表2 WHERE 条件...;
复制代码
  1. SELECT 字段列表 FROM 表1 [INNER] JOIN 表2 ON 连接条件...;
复制代码
连接查询-外连接

  1. SELECT 字段列表 FROM 表1 LEFT [OUTER] JOIN 表2 ON 条件...;
复制代码
相当于查询表1(左表)的所有数据,包含表1和表2交集部分的数据。
  1. SELECT 字段列表 FROM 表1 RIGHT [OUTER] JOIN 表2 ON 条件...;
复制代码
相当于查询表2(右表)的所有数据,包含表1和表2交集部分的数据。
连接查询-自连接

自连接查询语法:
  1. SELECT 字段列表 FROM 表A 别名A JOIN 表A 别名B ON 条件...;
复制代码
自连接查询,可以是内连接查询,也可以是外连接查询。
联合查询-union,uinon all

对于union查询,就是把多次查询的结果合并起来,形成一个新的查询结果集。
  1. SELECT 字段列表 FROM 表A ...
  2. UNION [ALL]
  3. SELECT 字段列表 FROM 表B ...;
复制代码
注意:
子查询

  1. SELECT * FROM 表1 WHERE column1 = (SELECT column1 FROM 表2);
复制代码
子查询外部的语句可以是INSERT/UPDATE/DELETE/SELECT的任何一个。
标量子查询

子查询返回的结果是单个值(数字、字符串、日期等),最简单的形式,这种子查询称为标量子查询。

常用的操作符:=      >   >=    <




欢迎光临 IT评测·应用市场-qidao123.com技术社区 (https://dis.qidao123.com/) Powered by Discuz! X3.4