SQL基础-连接表
一、连接表
1、SQL JOIN
忘记在哪保存的某位网友的图,先明白SQL JOIN,

2、关于笛卡尔积
笛卡尔积:
两个集合的乘积 重新建student表和teacher表: student表:
CREATE TABLE `student` (
`student_id` varchar(50) NOT NULL COMMENT '学生编号',
`student_name` varchar(100) NOT NULL DEFAULT '' COMMENT '学生姓名',
`teacher_id` varchar(20) DEFAULT NULL COMMENT '老师编号'
) ENGINE=MyISAM DEFAULT CHARSET=gbk COMMENT='学生'; INSERT INTO `student` VALUES ('S20180001','方东美','T0003'),('S20180013','陈顺军','T0004'),('S20170001','陈慧','T0008'); teacher表:
CREATE TABLE `teacher` (
`teacher_id` varchar(255) DEFAULT NULL COMMENT '老师编号',
`teacher_name` varchar(255) DEFAULT NULL COMMENT '老师姓名'
) ENGINE=MyISAM DEFAULT CHARSET=gbk COMMENT='老师'; INSERT INTO `teacher` VALUES ('T0001','高齐妍'),('T0002','李红'),('T0003','李一萱'),('T0004','刘金霞');

交叉连接CROSS JOIN,实现两个集合的笛卡尔积
SELECT * FROM student CROSS JOIN teacher;
3、内连接INNER JOIN
比如:
如何同时查询出学生编号、学生姓名对应的 老师编号、老师姓名? select * from student a INNER JOIN teacher b ON a.teacher_id = b.teacher_id; 相反的,如何返回这两张表里,老师编号不相同的记录? select * from student s inner join teacher t on s.teacher_id <> t.teacher_id;
4、全外连接FULL OUTER JOIN
比如:
如何同时查询出学生编号、学生姓名、老师编号、老师姓名? select * from student a FULL OUTER JOIN teacher b ON a.teacher_id = b.teacher_id; MySQL不支持FULL OUTER JOIN;
5、左外连接FULL OUTER JOIN
有时候只想要左表字段不为NULL的数据,而不需左表字段为NULL的数据; 比如:
如何同时查询出学生编号、学生姓名、老师编号、老师姓名? select * from student a LEFT OUTER JOIN teacher b ON a.teacher_id = b.teacher_id;
6、右外连接FULL OUTER JOIN
有时候只想要右表字段不为NULL的数据,而不需右表字段为NULL的数据; 比如:
如何同时查询出学生编号、学生姓名、老师编号、老师姓名? select * from student a RIGHT OUTER JOIN teacher b ON a.teacher_id = b.teacher_id;
二、复杂的连接表
1、建表、插入数据
##student表
CREATE TABLE `student` (
`student_id` varchar(50) NOT NULL COMMENT '学生编号',
`student_name` varchar(100) NOT NULL DEFAULT '' COMMENT '学生姓名',
`teacher_id` varchar(20) DEFAULT NULL COMMENT '老师编号',
`score` decimal(18,2) NOT NULL DEFAULT '0.00' COMMENT '数学成绩'
) ENGINE=MyISAM DEFAULT CHARSET=gbk COMMENT='学生'; INSERT INTO `student` VALUES ('S20180001','方东美','T0003',80.65),('S20180013','陈顺军','T0004',91.13),('S20170001','陈慧','T0004',94.99); ##teacher表
CREATE TABLE `teacher` (
`teacher_id` varchar(255) DEFAULT NULL COMMENT '老师编号',
`teacher_name` varchar(255) DEFAULT NULL COMMENT '老师姓名'
) ENGINE=MyISAM DEFAULT CHARSET=gbk COMMENT='老师'; INSERT INTO `teacher` VALUES ('T0001','高齐妍'),('T0002','李红'),('T0003','李一萱'),('T0004','刘金霞');
2、连接表的执行步骤
第一步:参与连接的两个表做笛卡尔积; 第二步:根据ON后的连接条件筛选笛卡尔积的结果; 第三步:补充左表(LEFT JOIN)或右表(RIGHT JOIN)不满足连接条件的数据(INNER JOIN内关联时无此步骤) ; 第四步:根据WHERE后的过滤条件筛选第三步的结果; SELECT *
FROM student a
LEFT JOIN teacher b
ON a.teacher_id = b.teacher_id
WHERE a.score > 90;
第一步:参与连接的两个表做笛卡尔积:

第二步:根据ON后的连接条件筛选笛卡尔积的结果:

第三步:补充左表(LEFT JOIN)或右表(RIGHT JOIN)不满足连接条件的数据(INNER JOIN内关联时无此步骤)

第四步:根据WHERE后的过滤条件筛选第三步的结果

3、LEFT JOIN与INNER JOIN

4、WHERE与ON
###
看两个SQL:
SELECT *
FROM student a
INNER JOIN teacher b
ON a.teacher_id = b.teacher_id
AND a.score>90; SELECT *
FROM student a
INNER JOIN teacher b
ON a.teacher_id = b.teacher_id
WHERE a.score>90; 根据步骤,inner join时不走第三步,所以只返回一条记录:
S20180013 陈顺军 T0004 91.13 T0004 刘金霞 ###
看两个SQL:
SELECT *
FROM student a
LEFT JOIN teacher b
ON a.teacher_id = b.teacher_id
AND a.score>90; SELECT *
FROM student a
LEFT JOIN teacher b
ON a.teacher_id = b.teacher_id
WHERE a.score>90; 根据步骤,第一条SQL left join时,要走第三步,AND是属于ON后面的,所以过滤后,又要补全left join不满住连接条件的数据:
第一条SQL的结果:
S20180013 陈顺军 T0004 91.13 T0004 刘金霞
S20180001 方东美 T0003 80.65
S20170001 陈慧 T0008 94.99 第二条SQL,执行完第三步,还要走第四步where
第二条SQL的结果:
S20180013 陈顺军 T0004 91.13 T0004 刘金霞
S20170001 陈慧 T0008 94.99
5、多表连接
##
第一步:a表与b表做LEFT JOIN;
第二步:a表与b表LEFT JOIN的结果,再与c表做LEFT JOIN;
...... 多表连接,就是第一张表与后面的表依次连接,重复执行表连接的步骤; 此时可以给student表加一个class_id列,数据如下:
S20180001 方东美 T0003 80.65 G0101
S20180013 陈顺军 T0004 91.13 G0102
S20170001 陈慧 T0008 94.99 G0201 如:
同时查看学生编号、学生姓名、老师编号、老师姓名、班级编号、班级名称: SELECT a.student_id,a.student_name,
a.teacher_id,b.teacher_name,
a.class_id,c.class_name
FROM student a
LEFT JOIN teacher b
ON a.teacher_id = b.teacher_id
LEFT JOIN class c
ON a.class_id = c.class_id;
6、非唯一键连接
表关联时,首先需要确认的一点,就是关联条件字段在关联表中是不是唯一。 在绝大多数的情况下,关联条件字段都是关联表中的主键或能唯一确定一条记录的字段。 如果不是,很可能是SQL的关联条件有问题,需要仔细确认是否与需求相符。
SQL基础-连接表的更多相关文章
- SQL基础-建表
一.建表 1.创建表的两种方式 *客户端工具 *SQL语句 2.使用SQL语句创建表 表名和字段名不能使用中文:(一般为字母开头,字母.数字.下划线组成的字符串): CREATE TABLE关键字后跟 ...
- Sql的连接表补充
连接条件可在FROM或WHERE子句中指定,建议在FROM子句中指定连接条件.WHERE和HAVING子句也可以包含搜索条件,以进一步筛选连接条件所选的行. 连接可分为 ...
- SQL基础-操纵表及插入、查询
一.操纵表 1.表的关键信息 2.更新表名 更新表名:使用RENAME TABLE关键字.语法如下: RENAME TABLE 旧表名 TO 新表名; 比如,生产环境投产前备份teacher表,使用如 ...
- (二十)sql基础
sql基础 --单表查询 select * from student; select * from score; --投影查询 select * from student; --条件查询 select ...
- mysql,SQL标准,多表查询中内连接,外连接,自然连接等详解之查询结果集的笛卡尔积的演化
先附上数据. CREATE TABLE `course` ( `cno` ) NOT NULL, `cname` ) CHARACTER SET utf8 NOT NULL, `ctime` ) NO ...
- SQL的多表连接查询
SQL的多表连接查询 多表连接查询具有两种规范,SQL92和SQL99规范. SQL92规范支持下列多表连接查询: (1)等值连接: (2)非等值连接: (3)外连接: (4)广义笛卡尔积: SQL9 ...
- [SQL]SQL Server数据表的基础知识与增查删改
SQL Server数据表的基础知识与增查删改 由张晨辉(学生) 于19天 前发表 | 阅读94次 一.常用数据类型 .整型:bigint.int.smallint.tinyint .小数:decim ...
- 章节2:SQL之多表连接
原文:章节2:SQL之多表连接 Sql的多表连接关系有:内连接.外连接和交叉连接. 先建立两个用于演示的表: TB_Characters: Id Character 1 内向 2 外向 3 中性性格 ...
- [SQL基础教程] 1-5 表的删除和更新
[SQL基础教程] 1-5 表的删除和更新 表的删除 语法 DROP TABLE <表名>; 法则 1-12 删除的表无法恢复 表定义的更新 语法 ALTER TABLE<表名> ...
随机推荐
- TCP,UDP 通讯的helper类
使用Tcp通讯,首先要启动tcp服务端监听客户端,客户端发送消息,服务端收到消息 1.服务端代码如下 public class TcpServerTest { public async Task Be ...
- Linux排查PHP-FPM进程过量常用命令
命令如下: 查看每个PHP-FPM进程的内存占用:ps -ylC php-fpm –sort:rss 查看消耗内存最多的前 40 个进程:ps auxw|head -1;ps auxw|sort -r ...
- 使用三层交换实现不同网段、不同 VLAN 互通
上一篇实现了使用Trunk做跨交换机VLAN通信,这一篇就试试使用三层交换实现不同网段,不同VLAN间的通信. 实验拓扑 在一台三层交换机下面连接一台二层交换机,再在二层交换机下面连接两台VPC,地址 ...
- spriingboot使用thymeleaf
1 添加jar包 <dependency> <groupId>org.springframework.boot</groupId> <artifactId&g ...
- php的冒泡排序
有其它语言基础, 这些套路弄起来就是快! 都在注释里~ <?php /** * 冒泡排序 PHP实现 * 原理:两两相邻比较,如果反序就交换,否则不交换 * 时间复杂度:最好 O(n) 最坏 O ...
- moviepy的常见用法
看了,还是自己弄这些方便. #字幕 >>> from moviepy.video.tools.subtitles import SubtitlesClip >>> ...
- linux的后台运行相关命令
screen -S name 创建一个名为name的后台,或者说bash面板,在这上面运行的任务不会因为连接断开而退出,且保留bash上的信息 screen -ls 列出所有的screen scree ...
- Calendar.getInstance()获取指定时间点(定时)
public class Test1 { public static void main(String[]args){ System.out.println("时间为:\n"+ge ...
- charAt,charCode,fromCharCode区别
1.charAt 返回字符串指定位置的字符 2.charCode 返回字符串指定位置字符Unicode编码 3.fromCharCode 用Unicode编码创建字符串 我们来看下例子 var str ...
- MySQL——时间戳和时间的转化
前言 Mysql中时间戳和时间的转化 时间转时间戳 select unix_timestamp('2019-7-29 14:23:25'); 时间戳转时间 select from_unixtime(1 ...