MySQL-----多表操作

news2024/9/24 11:31:18



介绍

        实际开发中,一个项目通常需要很多张表才能完成。例如:一个商城项目就需要分类表(category)、商品表(products)、订单表(orders)等多张表。且这些表的数据之间存在一定的关系,接下来我们将在单表的基础上,一起学习多表方面的知识。

一  多表关系

        MySQL多表之间关系可以概括为:一对一,一对多/多对一,多对多。

 ▶ 一对一关系

▣  一个学生只有一张身份证;一张身份证只能对应一学生。

▣  在任一表中添加唯一外键,指向另一方主键,确保一对一关系。

▣  一般一对一关系很少见,遇到一对一关系的表做好是合并表。

 ▶ 一对多关系/多对一关系

比如:部门和员工

分析:一个部门可以有多个员工,一个员工只能对应一个部门。

实现原则:在多的一方建立外键,指向一的一方的主键。

  ▶ 多对多关系

比如:学生和课程

分析:一个学生可以选择很多课程,一个课程也可以被很多学生选择。

原则:多对多关系实现需要借助第三张中间表。中间表至少包含两个字段,将多对多的关系,拆成一对多的关系,中间表至少要有两个外键,这两个外键分别指向原来那两张表的主键。



二  外键约束

介绍

        MySQL外键约束(FOREIGNKEY)是表的一个特殊字段,经常与主键约束一起使用。对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表(父表),外键所在的表就是从表(子表)。
        外键用来建立主表与从表的关联关系,为两个表的数据建立连接,约束两个表中数据的一致性和完整性。比如,一个水果摊,只有苹果、桃子、李子、西瓜等4种水果,那么,你来到水果摊要买水果就只能选择苹果、桃子、李子和西瓜,其它的水果都是不能购买的。

 ▶ 特点

定义一个主键时,需要遵守下列规则:

1.主表必须已经存在于数据库中,或者是当前正在创建的表。

2.必须为主表定义主键。

3.主键不能包含空值,但允许在外键中出现空值。也就是说,只要外键的每个非空值出现在指定的主键中,这个外键的内容就是正确的。

4.在主表的表名后面指定列明或列明组合。这个列或列的组合必须是主表的主键或候选键。

5.外键中列的数目必须和主表的主键中列的数目相同。

6.外键中列的数据必须和主表主键中对应的数据类型相同。


2-1.一对多关系

1.创建外键约束

 方式一:在创建表时设置外键约束

        constraint <外键名> foreign foreign key 字段名 [,字段名2,...] references <主表名> 主键列1 [,主键列2,...]

 方式一:在创建表后设置外键约束

        alter table <数据表名> add constraint <外键名> foreign key (<列名>) references <主表名> (<列名>);

 示例演示


2.操作外键约束数据

 1.插入数据

2.删除数据

 

 


3.删除外键约束

        当一个表不需要外键约束时,就需要从表中将其删除。外键一旦删除,就会解除主表和从表的关联关系。

语法格式:
        alter table <表名> drop foreign key <外键约束名>;

 



2-2.多对多关系

         在多对多关系中,A表的一行对应B的多行,B表的一行对应A表的多行,我们要新增加一个中间表,来建立多对多关系。

 1.创建多对多的关系

        创建两个主表和一个从表,为从表添加外键约束。

 

2.修改或删除表

         修改和删除表与上述的一对多的关系的操作语法一样,中间表(从表)可以随便删除和修改,但是两边的主表受从表依赖的数据不能删除或者修改。

 



三  多表联合查询

 介绍

        多表查询就是同时查询两个或两个以上的表,因为有的时候用户在查看数据的时候需要显示的数据来自多张表.多表查询有以下分类:

 ▶ 交叉连接查询[产生笛卡尔积,了解]
     语法: select * from A,B;        


 ▶ 内连接查询(使用的关键字inner join -- inner可以省略)


    隐式内连接(SQL92标准) : select * from A,B where条件;
    显示内连接(SQL99标准) : select * from A inner join B on条件;


 ▶ 外连接查询(使用的关键字outer join -- outer可以省略)
    左外连接:left outer join


        select* from A left outer join B on条件;
    右外连接: right outer join


        select * from A right outer join B on条件;
    满外连接: full outer join


        select * from A full outer join B on条件;


 ▶ 子查询
    select的嵌套


 ▶ 表自关联:
    将一张表当成多张表来用 

数据准备

1.交叉连接查询

 ▶ 简介

交叉连接查询返回被连接的两个表所有数据行的笛卡尔积。
笛卡尔积可以理解为一张表的每一行去和另外一张表的任意一行进行匹配。

假如A表有m行数据,B表有n行数据,则返回m*n行数据。
笛卡尔积会产生很多冗余的数据,后期的其他查询可以在该集合的基础上进行条件筛选。
 

  ▶ 格式

        select * from 表1,表2,表3....

  演示

 


2.内连接查询

 内连接查询求多张表的交集:

▶ 格式

隐式内连接(SQL92标准) : select * from A,B where条件;

显示内连接(SQL99标准) : select * from A inner join B on条件;

▶ 演示

 


3.外连接查询

        外连接分为左外连接(left outer join)、右外连接(right outer join),满外连接(full outer join)。

        注意: oracle里面有full join,可是在mysql对full join支持的不好。我们可以使用union来达到目。

 ▶ 格式

left:主要显示左表内容,右表没有的话填充null;

right:主要显示右表内容,左表没有的话填充null;

▶ 演示 


4.子查询

 简介

        子查询就是指的在一个完整的查询语句之中,嵌套若干个不同功能的小查询,从而一起完成复杂查询的一种编写形式,通俗一点就是包含select嵌套的查询。

 特点

子查询可以返回的数据类型一共分为四种:

1.单行单列:返回的是一个具体列的内容,可以理解为一个单值数据;

2.单行多列:返回一行数据中多个列的内容;
3.多行单列:返回多行记录之中同一列的内容,相当于给出了一个操作范围;
4.多行多列:查询返回的结果是一张临时表。

  演示

5.子查询关键字

        在子查询中,有一些常用的逻辑关键字,这些关键字可以给我们提供更丰富的查询功能,主要关键字如下:

1.ALL关键字
2.ANY关键字
3.SOME关键字
4.IN关键字
5.EXISTS关键字

5-1.关键字ALL 

 格式

select ...from ...where c >all(查询语句)
等价于:
select ...from ... where c > resultl and c > result2 and c >result3

▶ 特点

1.ALL:与子查询返回的所有值比较为true则返回true
2.ALL可以与=、>、>=,<、=、<>结合是来使用,分别表示等于、大于、大于等于、小于、小于等于、不等于其中的其中的所有数据。
3.ALL表示指定列中的值必须要大于子查询集的每一个值,即必须要大于子查询集的最大值;如果是小于号即小于子查询集的最小值。同理可以推出其它的比较运算符的情况。

 ▶ 演示


5-2.关键字ANY和SOME

 格式

select ...from ...where  c >any(查询语句)
等价于:
select ...from ... where c > resultl or c > result2 or c >result3

▶ 特点

1.ANY:与子查询返回的任何值比较为true则返回true
2.ANY可以与=、>、>=-、<、<=,<>结合是来使用,分别表示等于、大于、大于等于、小于、小于等于、不等于其中的其中的任何一个数据。
3.表示制定列中的值要大于子查询中的任意一个值,即必须要大于子查询集中的最小值。同理可以推出其它的比较运算符的情况。
4.SOME和ANY的作用一样,SOME可以理解为ANY的别名

 ▶ 演示


 5-3.关键字IN

 格式

select ...from ...where  c in(查询语句)
等价于:
select ...from ... where c = resultl or c = result2 or c = result3

▶ 特点

1.IN关键字,用于判断某个记录的值,是否在指定的集合中.

2.在IN关键字前边加上not可以将条件反过来.

 ▶ 演示

 


  5-3.关键字EXISTS

 格式

select ...from ...where exists(查询语句)

▶ 特点

1.该子查询如果“有数据结果”(至少返回一行数据),则该EXISTS()的结果为“true",外层查询执行
2.该子查询如果“没有数据结果”(没有任何数据返回),则该EXISTS()的结果为“false",外层查询不执行
3.EXISTS后面的子查询不返回任何实际数据,只返回真或假,当返回真时 where条件成立

4.注意,EXISTS关键字,比IN关键字的运算效率高,因此,在实际开发中,特别是大数据量时推荐使用EXISTS关键字

 ▶ 演示

 


6.自关联查询

 ▶ 概念

        MySQL有时在信息查询时需要进行对表自身进行关联查谊,即一张表自己和自己关联,一张表当成多张表来用。注意自关联时表必须给表起别名。

  格式

select    字段列表  from 表1  a , 表1  b  where  条件;

或者
select   字段列表   from 表1 a [left]  join   表1 b  on  条件;

 

   演示

我们先创建一个表使其自关联:
 

 

插入数据:

 自关联查询演示:

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1463601.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PostgreSQL限制密码的有效期(每次增加180天)

一、创建用户时&#xff0c;指定密码在180天后过期 创建用户时&#xff0c;可以使用如下语句&#xff0c;自动在当前时间的基础上增加180天&#xff0c;作为这个用户密码的有效时间。等到密码到期后或者临近的时候&#xff0c;可以使用SQL修改用户密码&#xff0c;并且重新定义…

echats 时间直方图示例

需求背景 某订单有N个定时任务&#xff0c;每个任务的执行时间已经确定&#xff0c;希望直观的查看该订单的任务执行趋势 查询SQL&#xff1a; select UNIX_TIMESTAMP(DATE_FORMAT(exec_time,%Y-%m-%d %H:%i)) execTime, count(*) from order_detail_task where order_no 2…

【命令行工具kubectl】

如何在k8s的任意节点使用用kubectl # 正常在node节点上是无法执行kubectl命令 [rootk8s-node-01 ~]# kubectl get pods The connection to the server localhost:8080 was refused - did you specify the right host or port?1、将master节点中/etc/kubernetes/,admin.conf拷…

Led灯驱动添加原子操作后驱动程序测试

一. 简介 上一篇文章实现了&#xff08;Linux驱动代码中&#xff09; 对 led灯的互斥处理&#xff0c;即使用Linux内核提供的处理并发与竞争的处理方法&#xff1a;原子操作。文章地址如下&#xff1a; Linux内核中并发与竞争的处理方法&#xff1a;原子操作举例-CSDN博客 …

React 模态框的设计(一)拖动组件的设计

春节终结束了&#xff0c;忙得我头疼。终于有时间弄自己的东西了。今天来写一个关于拖动的实例讲解。先看效果&#xff1a; 这是一个简单的组件设计&#xff0c;如果用原生的js设计就很简单&#xff0c;但在React中有些事件必须要多考虑一些。这是一个系列的文章&#xff0c;…

本机windows搭建达摩院与高德联合出品的地理地址自然语言处理模型GMeo实战

文章目录 本机windows搭建达摩院与高德联合出品的地理地址自然语言处理模型GMeo实战简介多模态地理文本预训练模型MGeoGeoGLUE 环境安装ModelScope相关安装conda虚拟环境深度学习基础库安装modelscope模型 测试代码代码输入xlsx文件运行这段测试代码输出xlsx耗时 如果有自定义样…

PLC_博图系列☞基本指令“异或“运算

PLC_博图系列☞基本指令“异或“运算 文章目录 PLC_博图系列☞基本指令“异或“运算背景介绍X&#xff1a;“异或”运算说明参数示例真值表 关键字&#xff1a; PLC、 西门子、 博图、 Siemens 、 异或 背景介绍 这是一篇关于PLC编程的文章&#xff0c;特别是关于西门子的…

Python如何运用turtle绘制阴阳太极图

本文详细分析如何使用Python turtle绘制阴阳太极图&#xff0c;先来分解这个图形&#xff0c;图片中有四种颜色&#xff0c;每条曲线上的箭头表示乌龟移动的方向&#xff0c;首先从中心画一个半圆&#xff08;红线&#xff09;&#xff0c;以红线所示圆的直径作半径画一个校园&…

Leo赠书活动-18期 《高效使用Redis》

✅作者简介&#xff1a;大家好&#xff0c;我是Leo&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Leo的博客 &#x1f49e;当前专栏&#xff1a; 赠书活动专栏 ✨特色专栏&#xff1a;…

机器学习面试:逻辑回归与朴素贝叶斯区别

逻辑回归与朴素贝叶斯区别有以下几个方面: (1)逻辑回归是判别模型&#xff0c;朴素贝叶斯是生成模型&#xff0c;所以生成和判别的所有区别它们都有。 (2)朴素贝叶斯属于贝叶斯&#xff0c;逻辑回归是最大似然&#xff0c;两种概率哲学间的区别。 (3)朴素贝叶斯需要条件独立假设…

#1.4w字长文#仿抖音项目架构设计与实现

一、项目介绍 本文介绍了一个Web端短视频应用&#xff0c;致力于为用户提供交互友好、功能完备的短视频浏览体验和直播体验。 集成了Gorse推荐算法&#xff0c;旨在为用户提供更个性化的推荐视频流和更权威的热门视频流。接入大模型&#xff0c;通过对视频内容进行语言分析&a…

大数据Kafka--概述

文章目录 概述定义消息队列传统消息队列的应用场景消息队列的两种模式 Kafka基础架构 Kafka快速入门安装部署集群规划集群部署集群启停脚本 Kafka命令行操作主题命令行操作生产者命令行操作消费者命令行操作 概述 定义 消息队列 目前企业中比较常见的消息队列产品主要有 Kafk…

C/C++的内存管理(1)

内存管理 C与C的内存分布C语言中动态内存管理方式回顾C内存管理的方式 C与C的内存分布 我们学习C语言时就知道&#xff0c;储存不同的变量计算机会相应分配不同区块的内存。那为什么要把内存化为不同的区域呢&#xff1f;实质上是为了方便管理 下面我们来看看下面一道例题&…

了解JSON的作用及其方法

什么是json JSON&#xff08;JavaScript Object Notation&#xff09;是一种轻量级的数据交换格式采用完全独立编程语言的文本格式存储和表示数据&#xff08;就是字符串&#xff09;。它基于JavaScript语法&#xff0c;但可以被多种编程语言使用和解析。JSON以键值对的形式存…

05 类和对象 3

目录 再谈构造函数static成员友元内部类匿名对象拷贝对象时一些编译器优化再次理解封装 1. 再谈构造函数 1.1 构造函数赋值 在创建对象时&#xff0c;编译器调用构造函数&#xff0c;给对象中各个成员变量一个合适的初始值 class Date { public: Date(int year, int month,…

前端基础自学整理|DOM树

DOM&#xff0c;文档对象模型&#xff08;Document Object Model&#xff09;&#xff0c;简单的说&#xff0c;DOM是一种理念&#xff0c;一种思想&#xff0c;一个与系统平台和编程语言无关的接口&#xff0c;一种方法, 使 Web开发人员可以访问HTML元素&#xff01;不是具体方…

MySQL语句大全

MySQL语句大全 数据库操作数据表操作往表中插入数据修改表中数据删除表中数据查询表中数据用户管理函数约束 (限制表中的字段值)多表查询事务 数据库操作 -- 显示数据库 show databases;-- 创建一个数据库 demo create database demo;-- 若不存在数据库 demo 则创建一个数据库…

软件测试基础篇(完整版)

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 “尽早的介入测试&#xff0c;遇到问题的解决成本就越低” 随着软件测试技术的发展&#xff0c…

Flutter NestedScrollView 内嵌视图滚动行为一致

Flutter NestedScrollView 内嵌视图滚动行为一致 视频 https://youtu.be/_h7CkzXY3aM https://www.bilibili.com/video/BV1Gh4y1571p/ 前言 上一节讲了 CustomScrollView &#xff0c;可以发现有的地方滚动并不是很连贯。 这时候就需要 NestedScrollView 来处理了。 今天会写…

Promise中的链式流

如果阅读有疑问的话&#xff0c;欢迎评论或私信&#xff01;&#xff01; 本人会很热心的阐述自己的想法&#xff01;谢谢&#xff01;&#xff01;&#xff01; 携手共进&#xff01; 文章目录 前言深入Promise链式流 前言 在探索Promise链式流之前我们要知道两个Promise固有…