一、连接表

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基础-连接表的更多相关文章

  1. SQL基础-建表

    一.建表 1.创建表的两种方式 *客户端工具 *SQL语句 2.使用SQL语句创建表 表名和字段名不能使用中文:(一般为字母开头,字母.数字.下划线组成的字符串): CREATE TABLE关键字后跟 ...

  2. Sql的连接表补充

        连接条件可在FROM或WHERE子句中指定,建议在FROM子句中指定连接条件.WHERE和HAVING子句也可以包含搜索条件,以进一步筛选连接条件所选的行.             连接可分为 ...

  3. SQL基础-操纵表及插入、查询

    一.操纵表 1.表的关键信息 2.更新表名 更新表名:使用RENAME TABLE关键字.语法如下: RENAME TABLE 旧表名 TO 新表名; 比如,生产环境投产前备份teacher表,使用如 ...

  4. (二十)sql基础

    sql基础 --单表查询 select * from student; select * from score; --投影查询 select * from student; --条件查询 select ...

  5. mysql,SQL标准,多表查询中内连接,外连接,自然连接等详解之查询结果集的笛卡尔积的演化

    先附上数据. CREATE TABLE `course` ( `cno` ) NOT NULL, `cname` ) CHARACTER SET utf8 NOT NULL, `ctime` ) NO ...

  6. SQL的多表连接查询

    SQL的多表连接查询 多表连接查询具有两种规范,SQL92和SQL99规范. SQL92规范支持下列多表连接查询: (1)等值连接: (2)非等值连接: (3)外连接: (4)广义笛卡尔积: SQL9 ...

  7. [SQL]SQL Server数据表的基础知识与增查删改

    SQL Server数据表的基础知识与增查删改 由张晨辉(学生) 于19天 前发表 | 阅读94次 一.常用数据类型 .整型:bigint.int.smallint.tinyint .小数:decim ...

  8. 章节2:SQL之多表连接

    原文:章节2:SQL之多表连接 Sql的多表连接关系有:内连接.外连接和交叉连接. 先建立两个用于演示的表: TB_Characters: Id Character 1 内向 2 外向 3 中性性格 ...

  9. [SQL基础教程] 1-5 表的删除和更新

    [SQL基础教程] 1-5 表的删除和更新 表的删除 语法 DROP TABLE <表名>; 法则 1-12 删除的表无法恢复 表定义的更新 语法 ALTER TABLE<表名> ...

随机推荐

  1. nmon2influxdb+grafana:服务监控可视化部署

    在工作中,无论是定位线上问题,还是性能优化,都需要对前端.后台服务进行监控.而及时的获取监控数据,能更好的帮助技术人员排查定位问题. 前面的博客介绍过服务端监控工具:Nmon使用方法及利用easyNm ...

  2. 警告:MySQL-server-5.6.26-1.el7.x86_64.rpm: 头V3 DSA/SHA1 Signature, 密钥 ID 5072e1f5: NOKEY

    警告:MySQL-server--.el7.x86_64.rpm: 头V3 DSA/SHA1 Signature, 密钥 ID 5072e1f5: NOKEY 错误:依赖检测失败: /usr/bin/ ...

  3. System.Web.NullPointerException

    在.Net异步webApi中我们需要记录日志信息,需要获取客户端的ip地址,我们需要使用:HttpContext.Current.Request.ServerVariables["REMOT ...

  4. C# 多线程与高并发处理并且具备暂停、继续、停止功能

    --近期有一个需要运用多线程的项目,会有并发概率,所以写了一份代码,可能有写地方还不完善,后续有需求在改 1 /// <summary> /// 并发对象 /// </summary ...

  5. Asp.net MVC 之ActionResult

    ActionResult 派生出以下子类: ViewResult 返回一个网页视图 PartialViewResult 返回一个网页视图,但不适用布局页. ContentResult 返回一段字符串文 ...

  6. Deployment.spec.selector.matchLables实验解释

    原文:https://cloud.tencent.com/developer/article/1394657 Deployment.spec.selector.matchLables实验解释 作者: ...

  7. 一文读懂内网、公网和NAT

    我们做弱电监控系统的时候,都避免不了要跟IP地址打交道,比如摄像头.NVR.服务器等这些设备安装好之后,就需要给它们配上IP,那这个IP地址你了解嘛?今天我们就一起来聊聊什么是内网.公网和NAT地址转 ...

  8. MySQL数据库基本规范整理

    此篇文章是学习MySQL技术整理的,不足之处还望指教,不胜感激. 数据库基本规范涉及数据库命名规范.数据库索引设计规范.数据库基本设计规范.数据库字段设计规范.数据库SQL开发规范.数据库操作行为规范 ...

  9. js对象及函数(四)

    一.对象1.函数对象的创建方法一:使用new构造函数去创建构造函数对象eg: var obj = new Object(); //向对象里面添加属性或方法 obj.name = 'nzc'; obj. ...

  10. JavaScript之控制标签css

    控制标签css标签.style.样式='样式具体的值'如果样式出现中横线,如border-radius,将中横线去掉,中横线后面的单词首字母大写,写成borderRadius如果原来就要该样式,表示修 ...