iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL多表联查的实现思路
  • 427
分享到

MySQL多表联查的实现思路

MySQL多表联查有几种方法MySQL多表联查语句 2023-02-21 09:02:07 427人浏览 安东尼
摘要

目录多表联查场景一对一多对一多对多内连接查询外连接自连接联合查询子查询多表联查场景 一对一 用户与用户信息表:当用户的信息数据过多时,我们可以将其分成两个表分别对应用户基本信息和用户的详情信息。 create table

多表联查场景

一对一

用户与用户信息表:当用户的信息数据过多时,我们可以将其分成两个表分别对应用户基本信息和用户的详情信息。

create table user(
    `id` int auto_increment primary key comment'用户id',
    `name` varchar(10),
    `age` varchar(10),
    `gender` char,
    `tel` varchar(30),
    `school` varchar(20),
    `addr` varchar(20),
    `degree` varchar(10),
    `university` varchar(10)
);

当用户信息过多时,就可以使用外键进行关联。在任意一方加入外键,关联另一方主键,并且设置外键为唯一的UNIQUE如下实现:

create table user(
    `id`  	 int auto_increment primary key,
    `name`   varchar(10),
    `age`    varchar(10),
    `gender` char
);
create table user_info(
    `id`         int auto_increment primary key ,
    `tel`        varchar(30),
    `school`     varchar(20),
    `addr`       varchar(20),
    `degree`     varchar(10),
    `university` varchar(10),
    `user_id` int unique,
    constraint fk_user_info foreign key (user_id) references user(id)
);

多对一

部门与员工:一个员工对应一个部门,一个部门对应多个员工

员工指向多的一方,部门指向一的一方。此时应该在员工表中创建外键,指向部门表中的主键

# 员工表
create table emp
(
  `emp_id`      int auto_increment primary key,
  `emp_name`    varchar(20) not null,
  `emp_gender`  char,
  `emp_tel`     varchar(30),
  `emp_dept_id` int,
  constraint fk_emp_dept foreign key (emp_dept_id) references dept (dept_id)
);
# 部门表
create table dept
(
  `dept_id` int auto_increment primary key,
  `dept_name` varchar(20) not null
);

查询方法:

-- 正常单表查
select * from emp;
-- 全查 笛卡尔积
select * from emp,dept;
-- 联查 消除无效的笛卡尔积
select * from emp,dept where emp_dept_id = dept.dept_id;

多对多

学生与课程:一个学生可以选修多门课程,一门课程可以被多个学生选择

此时我们应该在学生表与课程表之间建立中间表。中间表包含两个外键,分别对应学生表和课程表的主键

首先我们准备好数据,学生表+课程表+中间信息表

# 学生表
CREATE TABLE student(
	id INT auto_increment PRIMARY KEY COMMENT '主键ID',
	name VARCHAR(10) COMMENT '姓名',
	no VARCHAR(10) COMMENT '学号'
)COMMENT '学生表';
INSERT INTO student VALUES(NULL,'小瘪三','2001'),(NULL,'小瘪四','2002'),(NULL,'小瘪五','2003'),(NULL,'小瘪六','2004');
# 课程表
CREATE TABLE course(
	id INT auto_increment PRIMARY KEY COMMENT'主键ID',
	name VARCHAR(10) COMMENT '课程名称'
)COMMENT '课程表';
INSERT INTO course VALUES(NULL,'Java'),(NULL,'PHP'),(NULL,'Mysql'),(NULL,'hadoop');

# 学生课程关系表(中间表)
CREATE TABLE student_course(
	id INT auto_increment COMMENT '主键' PRIMARY KEY,
	student_id INT NOT NULL COMMENT '学生ID',
	course_id INT NOT NULL COMMENT '课程ID',
	CONSTRAINT fk_course_id FOREIGN KEY (course_id) REFERENCES course (id),
	CONSTRAINT fk_student_id FOREIGN KEY (student_id) REFERENCES student (id)
)COMMENT '学生——课程关系中间表';
INSERT INTO student_course VALUES(null,1,1),(null,1,2),(null,1,3),(null,2,2),(null,2,3),(null,3,4);

我们切换idea打开可以清晰的看到三个表之间的关系,中间信息表中的两个外键:student_id与course_id将学生表和课程表关联了起来

MySQL多表联查的实现思路

内连接查询

查询A集合与B集合的交集

-- 方式一
select [字段列表] from 表1,表2 where 条件...;
-- 方式二
select [字段列表] from 表1 inner join 表2 on 条件...;

示例:查询所有员工与其所属部门

-- 方式一
select emp_name,dept_name from emp inner join dept d on emp.emp_dept_id = d.dept_id;
-- 方式二
select emp_name,dept_name from emp,dept where emp.emp_dept_id = dept.dept_id;

外连接

右外连接:查询右表所有数据以及两表交集部分数据

select 字段列表 from 表1 right outer join 表2 on 条件...;

左外连接:查询左表所有数据以及两表交集部分数据

select 字段列表 from 表1 left outer join 表2 on 条件...;

示例:

-- 2. 查询员工全部信息及其对应的部门信息 左外连接
select  e.*,dept_name from emp e left join dept d on d.dept_id = e.emp_dept_id;
-- 3. 查询全部部门和其对应的所有员工信息 右外连接
select d.*,e.emp_name from emp e right join dept d on e.emp_dept_id = d.dept_id;

自连接

当前表与自身的连接查询,自连接必须使用别名

格式:

select 字段列表 from 表A 别名 join 表A 别名 on 条件...;

在员工表中,所有的普通员工、管理者都是员工。查询每个员工归属哪个管理者管理就需要用到自连接

select a.name,b.name from emp a join emp b on a.emp_id = b.manager_id;

联合查询

关键字 uNIOn [all] 将两条sql语句查询的结果拼接起来

-- 查询年龄大于50的员工  和薪资小于10000的员工
select * from emp where emp.emp_age > 50
union all
select * from emp where emp.emp_salary < 10000;

加上all表示不会去重,不加all表示去重复(即同时满足两条sql语句的只出现一次即可)

多张表的列数必须保持一致,字段类型也需要一致

子查询

子查询是指在SQL语句中嵌套select语句进行嵌套查询

select * from t1 where column1 =(select column1 from t2);

子查询的外部语句可以是insert、uodate、delete、select的任何一个

标量子查询示例:查询‘ 开发部 ’的全部员工信息

首先你可以利用正常的两条sql去查询:

-- 查询“开发部”的所有员工
-- 1. 两条语句查询
select dept_id from dept where dept_name = '开发部';
select emp_name from emp where emp_dept_id = 1;

或者你可以使用内连接方式进行联查:

-- 内连接
select e.emp_name,d.dept_name from emp e inner join dept d on e.emp_dept_id = d.dept_id where dept_name = '开发部';

或者使用子查询:

-- 使用子查询
select * from emp where emp_dept_id = (select dept_id from dept where dept_name = '开发部');

到此这篇关于mysql多表联查的实现思路的文章就介绍到这了,更多相关MySQL多表联查内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL多表联查的实现思路

本文链接: https://www.lsjlt.com/news/196844.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL多表联查的实现思路
    目录多表联查场景一对一多对一多对多内连接查询外连接自连接联合查询子查询多表联查场景 一对一 用户与用户信息表:当用户的信息数据过多时,我们可以将其分成两个表分别对应用户基本信息和用户的详情信息。 create table...
    99+
    2023-02-21
    MySQL多表联查有几种方法 MySQL多表联查语句
  • MySQL多表联查如何实现
    本文小编为大家详细介绍“MySQL多表联查如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL多表联查如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。多表联查场景一对一用户与用户信息表:当用户...
    99+
    2023-07-05
  • MyBatis-Plus实现多表联查
    MyBatis-Plus多表联查写法 前言一、引依赖二、使用方法三、(实战)多表查询参数说明 四、(实战)多表分页查询 前言 收获大佬封装的一个jar包,可以支持MyBatis-...
    99+
    2023-09-03
    mybatis java sql
  • MySQL的多表关联查询
    一、多表关联查询 多表关联查询是使用一条SQL语句,将关联的多张表的数据查询出来。 1.1 交叉查询 交叉查询就是将多张表的数据没有条件地连接在一起进行展示。 1.1.1 语法 使用交叉查询类别和商品 -- 目标:查询所有分类,以及每个分类...
    99+
    2023-08-22
    mysql 数据库 java
  • mybatis-plus多表联查join的实现
    目录1、安装依赖2、定义三个基本实体类3、定义三个mapper4、定义返回值dto5、开发业务层6、假如进行分页查询的话7、注意:8、其他9、如果针对条件进行动态查询1、安装依赖 &...
    99+
    2023-01-11
    mybatis-plus多表联查 mybatis-plus多表联查join
  • 【MySQL】MySQL表之联合查询(多表查询)
    📌前言:本篇博客介绍MySQL数据库的MySQL表之联合查询(多表查询),学习MySQL之前要先安装好MySQL,如果还没有安装的小伙伴可以看看博主前面的博客,里面有详细的安装教程。 那我们废话不多说,直接进入主体!...
    99+
    2023-08-16
    mysql 数据库 java
  • Mysql 多表关联查询
    文章目录 1. Mysql中表之间的关系1.1 多表关系1.2 外键约束 2. 多表联合查询2.1 交叉连接查询:笛卡尔积2.2 内连接查询:inner join2.3 外连接查询2.3.1 左连接:2.3.2 右连接:2.3....
    99+
    2023-08-21
    mysql 数据库 sql
  • MySQL联合查询(多表查询)
    一、内连接 select *from 表1 [ inner | cross ] join 表2 [ on过滤条件 ] [ where查询条件 ] ; [ inner | cross ]: join 内连接关键字(必须要有...
    99+
    2023-09-14
    mysql 数据库 database
  • mysql中如何实现多表联合查询操作
    这篇文章将为大家详细讲解有关mysql中如何实现多表联合查询操作,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。MySQL多表联合查询语法:复制代码 代码如下...
    99+
    2024-04-02
  • MySQL多表关联查询实例分析
    本篇内容介绍了“MySQL多表关联查询实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!数据库设计范式目前数据库设计有五种范式 , 一般...
    99+
    2023-06-30
  • MyBatis-Plus怎么实现多表联查
    这篇文章主要介绍“MyBatis-Plus怎么实现多表联查”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MyBatis-Plus怎么实现多表联查”文章能帮助大家解决问题。建库建表DROP&n...
    99+
    2023-06-29
  • MongoDB中如何实现多表联查
    今天小编给大家分享一下MongoDB中如何实现多表联查的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。前些天遇到一个需求,不复...
    99+
    2023-07-02
  • MyBatis实现多表联查的详细代码
    目录一、通过映射配置文件实现多表联查二、使用注解的方式一、通过映射配置文件实现多表联查 首先,使用Mysql数据库,创建两个表,分别为学生表Student表和班级表Class表,在S...
    99+
    2022-11-13
    MyBatis多表联查 MyBatis多表查询
  • Hibernate多表关联查询怎么实现
    本篇内容介绍了“Hibernate多表关联查询怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、Hibernate简介Hiberna...
    99+
    2023-06-17
  • oracle多表关联查询如何实现
    在Oracle数据库中,可以使用SQL语句实现多表关联查询。以下是一个示例: 假设有两个表:表A和表B,它们有一个共同的字段ID可以...
    99+
    2024-04-09
    oracle
  • Mysql多表联查——经典50题
    目录 1、查询"01"课程比"02"课程成绩高的学生的信息及课程分数。2、查询每门功成绩最好的前两名 。3.查询平均成绩大于等于60分的同学的学生编号和学生姓名和平均成绩。4.查询平均成绩小于60分的同学的学生编号和学生姓名和平均成...
    99+
    2023-08-19
    mysql 数据库 sql
  • mybatis-plus多表关联查询功能的实现
    学习目标: mybatis-plus多表关联查询 学习内容: mybatis-plus多表关联查询 实体类部分代码 @Data @AllArgsConstructor @NoAr...
    99+
    2024-04-02
  • mysql多表联查的方法有哪些
    MySQL多表联查的方法有以下几种: INNER JOIN:内连接,只返回两个表中共有的数据行。 LEFT JOIN:左连接,返回...
    99+
    2024-04-09
    mysql
  • java操作mongodb之多表联查的实现($lookup)
    最近在开发的过程中,一个列表的查询,涉及到了多表的关联查询,由于持久层使用的是mongodb,对这个非关系型数据使用的不是很多,所以在实现此功能的过程中出现了不少问题,现在此做记录,...
    99+
    2024-04-02
  • 如何在MySQL中实现联表查询
    这篇文章将为大家详细讲解有关如何在MySQL中实现联表查询,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。MySQL 中 JOIN, CROSS JOIN 和...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作