MySQL数据库之多表操作_shenzhuan7的博客-程序员宝宝

技术标签: 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=’赵四’).

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/shenzhuan7/article/details/50371194

智能推荐

怎么在电脑上创建一个虚拟机_MonkeyBananas的博客-程序员宝宝_电脑虚拟机怎么弄

在此之前从来没有装过虚拟机,悄悄告诉你们我是个程序员,哈哈哈,还被女友嘲笑了,所以今天来总结一下,大神请略过就好,纯属小白笔记,下面开始吧。1.第一步那就是要下载一个工具,我这里用的是Vmware Workstation,下载好之后,我们就可以创建虚拟机了。2.点击创建虚拟机。3.这里我使用的自定义安装虚拟机。4.这里就直接下一步就好了。5.这里需要注意了,要去下载...

十二张图带你了解 Redis 的数据结构和对象系统_互扯程序的博客-程序员宝宝

来自公众号:程序员历小冰Redis是一个开源的 key-value 存储系统,它使用六种底层数据结构构建了包含字符串对象、列表对象、哈希对象、集合对象和有序集合对象的对象...

maven无法加载本地jar包以及打包时本地jar没有打进去 的解决办法_花化世界的博客-程序员宝宝

在工作中有些jar包是本地生成的,无法在maven仓库中下载,需要将本地jar添加mavn依赖中。第一 依赖本地jar:<dependency> <groupId>com.icinfo</groupId> <artifactId>alesapi</artifactId> <version>1....

ftp服务器搭建_尓夳哯实的博客-程序员宝宝

文章目录@[TOC]ftp使用的软件及下载配置前的准备配置过程1、关闭虚拟机上的防火墙和selinux2、ftp服务的开启和设置开机自启3、ftp配置文件的编辑4、Windows客户端测试5、Linux客户端访问ftp测试ftp使用的软件及下载软件:vsftpd软件下载命令:yum install vsftpd -y配置前的准备两台虚拟机+Windows本机在这里我们使用两台虚拟机进行模拟搭建一个ftp服务器,另外一台虚拟机作为客户端进行访问ftp服务器,同时我们还可以使用Windows客户端进

VS 2019中利用C#语言在.Net Framework 4.5框架上开发简易串口发送数据软件_吮指原味张的博客-程序员宝宝

0. 前言前置项目为:VS 2019中利用C#语言在.Net Framework 4.5框架上开发简易倒计时器1. 项目实现1.1 配置Form1.cs[设计]文件在Form1.cs[设计]中放入如下控件,并在对应的属性框中设置好属性。拖入组件serialPort。在serialPort的属性栏内,可以设置波特率、串口号等属性。本程序采用的波特率为4800,串口号为COM4。1.2 配置Form1.cs文件Form1.cs的代码如下所示using System;using Syst

随便推点

BIO与NIO、AIO的区别(这个容易理解)_skiof007的博客-程序员宝宝_bio nio

IO的方式通常分为几种,同步阻塞的BIO、同步非阻塞的NIO、异步非阻塞的AIO。一、BIO     在JDK1.4出来之前,我们建立网络连接的时候采用BIO模式,需要先在服务端启动一个ServerSocket,然后在客户端启动Socket来对服务端进行通信,默认情况下服务端需要对每个请求建立一堆线程等待请求,而客户端发送请求后,先咨询服务端是否有线程相应,如果没有则会一直等待或者

计算机电子电路原理图,电子电路图 如何看懂电子电路图 凡亿教你如何看懂电路图..._一级翻译吴杰的博客-程序员宝宝

电路图电路图是人们为了研究和工程的需要,用约定的符号绘制的一种表示电路结构的图形。通过电路图可以知道实际电路的情况。这样,我们在分析电路时,就不必把实物翻来覆去地琢磨,而只要拿着一张图纸就可以了;在设计电路时,也可以从容地在纸上或电脑上进行,确认完善后再进行实际安装,通过调试、改进,直至成功;而现在,我们更可以应用先进的计算机软件来进行电路的辅助设计,甚至进行虚拟的电路实验,大大提高了工作效率。电...

LintCode 392. 打劫房屋 JavaScript算法_SmallTeddy的博客-程序员宝宝

描述假设你是一个专业的窃贼,准备沿着一条街打劫房屋。每个房子都存放着特定金额的钱。你面临的唯一约束条件是:相邻的房子装着相互联系的防盗系统,且 当相邻的两个房子同一天被打劫时,该系统会自动报警。给定一个非负整数列表,表示每个房子中存放的钱, 算一算,如果今晚去打劫,在不触动报警装置的情况下, 你最多可以得到多少钱 。样例- 样例 1:输入: [3, 8, 4]输出: 8解释: 仅仅打劫第二个房子.- 样例 2:输入: [5, 2, 1, 3] 输出: 8解释: 抢第一个和最后一个

如何判断一个字符串是否是回文字符串_程序员铁蛋的博客-程序员宝宝_判断字符串是否是回文串

/** * 判断一个字符串是不是回文串,比如:abcba是回文串 * @author zhaizhg * */public class Test3 { public static void main(String[] args) { String str = "abcba"; boolean calc = calc(str); System.out.println(calc); } static boolean calc(String s) { int left = 0

Flash Builder4.5安装破解_weixin_34344403的博客-程序员宝宝

具体步骤如下: 1.到Adobe官网上下载FlashBuilder_4_5_LS10.exe,有简体中文版的; 2.安装时,不用序列号,直接选择安装试用版; 3.安装完成后依次修改下列3个文件: (1)C:\Program Files\Adobe\Adobe Flash Builder 4.5\eclipse\.plugins\com.adobe.flexbuilder.project_4.5.1...

Git Cheat Sheet 中文版_赢阡的博客-程序员宝宝

Git Cheat Sheet 中文版本文内容来自我fork 并翻译的GitHub repo Git-Cheat-Sheet,如果内容有误或有新内容补充,欢迎大家给我发issue。Other Available Languages:Arabic Git Cheat SheetEnglish Git Cheat SheetHindi Git Cheat She