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

相关文章

MySQL8.0设置redo缓存大小的实现

《MySQL8.0设置redo缓存大小的实现》本文主要在MySQL8.0.30及之后版本中使用innodb_redo_log_capacity参数在线更改redo缓存文件大小,下面就来介绍一下,具有一... mysql 8.0.30及之后版本可以使用innodb_redo_log_capacity参数来更改

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多