MySQL数据库之多表操作

2023-12-02 10:48

本文主要是介绍MySQL数据库之多表操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先说一下什么是外键,外键是指引用另外一个表中的一列或多列,被引用的列应该具有主键约束或唯一性约束。使用外键的好处就是保证数据的完整性。比如说有一个班级表和一个学生表,当删除一个班级的时候,学生表中班级的id就相当于是垃圾数据或者错误数据。所以学生表使用外键关联到班级表,当删除班级的时候,只有学生表中没有使用该班级的id(也就是没有该班级的学生时)才可以删除班级,若有学生的话,必须先删除学生,或者把学生表中班级的id值空。才可以删除。如何为表添加外键呢:alter table 表名add constraint FK_ID foreign key (外键字段名) references 外表表名 (主键字段名);

如:alter table student add constraint FK_IDforeign key (class_id) references class (id);

删除外键的语句:alter table 表名drop foreign key 外键名;

如:alter table student drop foreign key FK_ID;

当学生表中引用班级表的id,就说明班级是主表,学生是从表。因为外键列只能插入参照列存在的值,所以如果要为两个表添加数据,就先为主表添加数据。

       多表操作的重点是连接查询和子查询。分别是:交叉连接—select * from 表1 cross join 表2;这种方法一般很少用。

下面说一下内连接—select 查询字段 from 表1 [inner] join表2 on 表1.关系字段 =表2.关系字段;

如:select employee.name, department.dname fromdepartment join employee on department.did=employee.did;

首先判断员工表的id是否等于部门表的id,也就是查各部门的员工。这句相当于:select employee.name, department.dname from department,employee where department.did=employee.did;

       外链接分为左连接、左外链接、右连接、右外链接,语法格式为:

Select 所有字段 from 表1 left|right [outer] join 表2 on 表1.关系字段=表2.关系字段 where 条件;

左连接:返回包括左表中的所以记录和有表中符合连接条件的记录。

右连接:返回包括右表中的所以记录和有表中符合连接条件的记录。

如:select department.did, department.dname, employee.namefrom department left join employee on department.did=employee.did;

id

dname

name

1

网络部

王红

1

网络部

李强

2

媒体部

赵四

3

研发部

null

5

人事部

Null

而右连接是这样的:如:

select department.did,department.dname, employee.name from department right join employee ondepartment.did=employee.did;

id

dname

Name

1

网络部

王红

1

网络部

李强

2

媒体部

赵四

Null

null

何娟

最后看一下子查询:子查询是嵌套在另一个语句内部的查询,可以嵌套在select、insert…into等中,在执行查询语句时,首先执行子查询,然后将返回结果作为外层语句的过滤条件。子查询包括IN、EXISTS、ANY、ALL。

下面直接上语句:select * from department where did [NOT] IN(select did from employee where age=20);查询存在员工年龄等于20 的部门;关键字exists只返回true或false,

select * fromdepartment where did exists(select did from employee where age>20);如果有年龄大于20的,就查询所有部门。ANY关键字表示满足其中任意一个条件便可。他们可以返回一个值列表,然后给外层查询进行比较,如:select * from department where did>any(selectdid from employee);查询员工表中的所以id,并返回一个id列表,供department 中的did比较,只要满足就返回。ALL关键字与ANY关键字类似,他要满足子查询的所有条件。select * from department where did>all(select didfrom employee);再看一条语句,select * from department where did=(selectdid from employee where name=’赵四’).

这篇关于MySQL数据库之多表操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/445046

相关文章

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

MySQL多实例管理如何在一台主机上运行多个mysql

《MySQL多实例管理如何在一台主机上运行多个mysql》文章详解了在Linux主机上通过二进制方式安装MySQL多实例的步骤,涵盖端口配置、数据目录准备、初始化与启动流程,以及排错方法,适用于构建读... 目录一、什么是mysql多实例二、二进制方式安装MySQL1.获取二进制代码包2.安装基础依赖3.清

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、