MySQL:多表操作

介绍

        实际开发中,一个项目通常需要很多张表才能完成。例如:一个商城项目就需要分类表(category)、商品表(products)、订单表(orders)等多张表,且这些表的数据之间存在一定的关系。

多表关系

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

一对一关系

  • 在任一表中添加唯一-外键, 指向另一方主键,确保-对一关系。
  • 一般一对一关系很少见,遇到一对一关系的表最好是合并表。

一对多/多对一关系

        部门和员工

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

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

多对多关系

        学生和课程

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

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

外键约束

介绍

        MySQL外键约束(FOREIGN KEY)是表的一个特殊字段,经常与主键约束一起使用。 对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表(父表) ,外键所在的表就是从表(子表)。

        外键用来建立主表与从表的关联关系,为两个表的数据建立连接,约束两个表中数据的一致性和完整性。

特点

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

  • 主表必须已经存在于数据库中,或者是当前正在创建的表。
  • 必须为主表定义主键。
  • 主键不能包含空值,但允许在外键中出现空值。也就是说,只要外键的每个非空值出现在指定的主键中,这个外键的内容就是正确的。
  • 在主表的表名后面指定列名或列名的组合。这个列或列的组合必须是主表的主键或候选键。
  • 外键中列的数目必须和主表的主键中列的数目相同。
  • 外键中列的数据类型必须和主表主键中对应列的数据类型相同。

创建外键约束

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

        在create table语句中,通过foreign key关键字来指定外键,具体的语法格式如下:

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

        外键约束也可以在修改表时添加,但是添加外键约束的前提是:从表中外键列中的数据必须与主表中主键列中的数据一致或者是没有数据。

在外键约束下的数据操作

数据插入
  1. 添加主表数据(注意必须先给主表添加数据)
  2. 添加从表数据(注意给从表添加数据时,外键列的值不能随便写,必须依赖主表的主键列)
删除数据
  • 主表的数据被从表依赖时,不能删除,否则可以删除
  • 从表的数据可以随便删除

删除外键约束

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

格式:

外键约束-多对多关系

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

        修改和删除时,中间从表可以随便删除和修改,但是两边的主表受从表依赖的数据不能删除或者修改

多表联合查询

介绍

        多表查询就是同时查询两个或两个以上的表,因为有的时候用户在查看数据的时候需要显示的数据来自多张表。外键约束对多表查询并无影响。

多表查询有以下分类: 

➢交叉连接查询 [产生笛卡尔积,了解]

        语法: 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的嵌套

➢表自关联:

        将一张表当成多张表来用

交叉连接查询

介绍

  •         交叉连接查询返回被连接的两个表所有数据行的笛卡尔积
  •         笛卡尔积可以理解为一张表的每一行去和另外一 张表的任意一行进行匹配
  •         假如A表有m行数据,B表有n行数据,则返回m*n行数据
  •         笛卡尔积会产生很多冗余的数据,后期的其他查询可以在该集合的基础上进行条件筛选

格式

内连接查询

介绍

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

格式

        inner可以省略不写

外连接查询

介绍

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

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

格式

左外连接: 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 条件;

  • outer可以省略
  • 满外连接可以用union (all)
  • union是将两个查询结果上下拼接,并去重
  • union all是将两个查询结果上下拼接,不去重

子查询

介绍

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

特点

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

  • 单行单列:返回的是一个具体列的内容,可以理解为一个单值数据
  • 单行多列:返回一行数据中多个列的内容
  • 多行单列:返回多行记录之中同一列的内容,相当于给出了一个操作范围
  • 多行多列:查询返回的结果是一张临时表

        子查询的临时表必须要有别名

子查询里的关键字

        在子查询中,有一些常用的逻辑关键字,这些关键字可以给我们提供更丰富的查询功能,主要关键字有:ALL、ANY、 SOME、IN、EXISTS。

ALL
        格式

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

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

        特点
  • IN关键字,用于判断某个记录的值,是否在指定的集合中
  • 在IN关键字前边加上not可以将条件反过来
EXISTS
        格式

        特点
  • 该子查询如果“有数据结果”(至少返回一行数据),则该EXISTS() 的结果为“true”, 外层查询执行
  • 该子查询如果“没有数据结果”(没 有任何数据返回),则该EXISTS()的结果为 “false", 外层查询不执行
  • EXISTS后面的子查询不返回任何实际数据,只返回真或假,当返回真时where条件成立
  • 注意,EXISTS关键字,比IN关键字的运算效率高,因此,在实际开发中,特别是大数据量时,推荐使用EXISTS关键字。

自关联查询

概念

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

格式

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【我与Java的成长记】之this引用和构造方法的使用详解

系列文章目录 能看懂文字就能明白系列 C语言笔记传送门 &#x1f31f; 个人主页&#xff1a;古德猫宁- &#x1f308; 信念如阳光&#xff0c;照亮前行的每一步 文章目录 系列文章目录&#x1f308; *信念如阳光&#xff0c;照亮前行的每一步* 前言一、this的使用this引用的特…

【C语言】初识C语言

本章节主要目的是基本了解C语言的基础知识&#xff0c;对C语言有一个大概的认识。 什么是C语言 在日常生活中&#xff0c;语言就是一种人与人之间沟通的工具&#xff0c;像汉语&#xff0c;英语&#xff0c;法语……等。而人与计算机之间交流沟通的工具则被称为计算机语言&am…

机器学习——损失函数

【说明】文章内容来自《机器学习——基于sklearn》&#xff0c;用于学习记录。若有争议联系删除。 1、简介 损失函数(loss function)又称为误差函数(error function)&#xff0c;是衡量模型好坏的标准&#xff0c;用于估量模型的预测值与真实值的不一致程度&#xff0c;是一个…

Translation翻译插件

Translation插件是为IntelliJ IDEA开发的&#xff0c;因此只能在IntelliJ IDEA中使用。但是&#xff0c;如果你需要在其他软件中进行翻译&#xff0c;可以考虑使用其他的翻译工具或服务。例如&#xff0c;一些在线翻译网站&#xff08;如Google翻译、百度翻译等&#xff09;提供…

Android Security PIN 相关代码

开发项目遇到一个问题&#xff0c;具体描述及复制步骤如下&#xff1a; 就是开启"Enhanced PIN privacy"(增强的PIN隐私)的时候输入秘密的时候还是会显示数字 如下图&#xff0c;应该是直接是“.” 不应该出现PIN 密码 想要的效果如下图&#xff1a; 设置的步骤如下图…

编写第一个APP自动化脚本 appium_helloworld ,将脚本跑起来

一、前置说明 我们把学习 Appium 的第一个脚本称为 appium_helloworld&#xff0c;它用于展示 Appium 的基本用法&#xff0c;验证配置和环境是否正确。 Appium 自动化操作 APP 的基本流程&#xff08;Android平台&#xff09;&#xff1a; 启动 Appium Serveradb 连接设备&…

【JavaScript】垃圾回收与内存泄漏

✨ 专栏介绍 在现代Web开发中&#xff0c;JavaScript已经成为了不可或缺的一部分。它不仅可以为网页增加交互性和动态性&#xff0c;还可以在后端开发中使用Node.js构建高效的服务器端应用程序。作为一种灵活且易学的脚本语言&#xff0c;JavaScript具有广泛的应用场景&#x…

Python 进阶(十八):配置文件(configparser 模块)

大家好&#xff0c;我是水滴~~ configparser模块是Python标准库中的一个模块&#xff0c;用于解析配置文件。它提供了一种简单而灵活的方式来读取、修改和写入INI格式的配置文件。本文将介绍该模块是如何操作配置文件的。 文章中包含大量的示例代码&#xff0c;希望能够帮助新…

Docker七 | 搭建Swarm集群

目录 创建Swarm集群 创建管理节点 增加工作节点 查看集群 部署服务 新建服务 查看服务 服务伸缩 增加服务 减少服务 删除服务 创建Swarm集群 创建管理节点 在192.168.117.131下执行docker swarm init命令的节点自动成为管理节点 [rootlocalhost ~]# docker swar…

同化的题解

时间限制: 1000ms 空间限制: 524288kB 题目描述 古人云&#xff1a;“近朱者赤近墨者黑”。这句话是很有道理的。这不鱼大大和一群苦命打工仔被安排进厂拧螺丝了。 进厂第一天&#xff0c;每个人拧螺丝的动力k都是不同且十分高涨的。但是当大家坐在一起后会聊天偷懒&#xf…

axios配置请求头content-type 和 get/post请求方式

axios配置请求头content-type https://blog.csdn.net/wojiushiwo945you/article/details/107653962 axios 是Ajax的一个插件&#xff0c;axios虽然是一个插件&#xff0c;但是我们不需要通过Vue.use(axios)来使用&#xff0c;下载完成后&#xff0c;只需在项目中引入即可。(一…

如何利用腾讯文档提升办公效率?

1. 实时协作功能&#xff1a;利用腾讯文档的实时协作功能&#xff0c;多人可以同时编辑和评论文档&#xff0c;大大提高团队工作效率。2. 云存储和同步&#xff1a;通过云存储和同步功能&#xff0c;方便地存储、访问和分享文档&#xff0c;不再受到时间和地点的限制。3. 版本控…