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

相关文章

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安

MySQL 中的 LIMIT 语句及基本用法

《MySQL中的LIMIT语句及基本用法》LIMIT语句用于限制查询返回的行数,常用于分页查询或取部分数据,提高查询效率,:本文主要介绍MySQL中的LIMIT语句,需要的朋友可以参考下... 目录mysql 中的 LIMIT 语句1. LIMIT 语法2. LIMIT 基本用法(1) 获取前 N 行数据(

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2