MySQL之表连接(内外连接和重命名的使用)
#要多练练
1.连接查询根据连接方式分为
内连接
等值连接
非等值连接
自连接
外连接
左外连接(左连接)
右外连接(右连接)
当多张表进行连接查询,若没有任何条件进行限制,会
发生什么现象?
会出现笛卡尔积,即两张表的记录的条数的乘积
##哪里用as?为什么这里不能用as?
#sql92:内连接中的等值连接
select e.ename,d.dname from emp e,dept d where e.deptno=d.deptno;
#SQL99:内连接中的等值连接,优点:对表连接不满意的话,
#可以再追加where进行过滤。
select e.ename,d.dname from emp e join dept d on e.deptno=d.deptno;
#SQL99:内连接中的非等值连接?
#eg:显示薪水等级、部门名、薪水等
select e.ename,e.sal,s.grade from emp e join salgrade s on e.sal between s.losal and s.hisal;
#找出每个员工的上级领导的名称,说明领导也从属于员工表,所以要
#把一张表看成两张表(a、b两张表)。
select a.ename empname,b.ename leadrname from emp a inner join emp b on a.mgr=b.empno; select a.ename empname,b.ename leadername from emp a join emp b on a.mgr=b.empno;
#找出每个员工对应的部门名称,要求显示全部
#部门名全部显示
select e.ename,d.dname from emp e right join dept d on d.deptno=d.deptno;
#什么时候用外连接?什么时候用内连接?
#内连接的记录条数小于等于外连接,内连接
#是会显示相匹配的信息,对于不完整的信息不会显示
#而外连接(无条件的全部显示)是会对全部进行显示的
#左连接是将左边全部显示出来,而右连接是将右边全部
#显示出来,若无记录则用null来匹配
#案例:找出每个员工对应的领导名,要求显示
#所有的员工
select a.ename empname,b.ename leadername
from emp a
left join emp b
on a.mgr=b.empno;
#把一张表看成a、b两张表
#案例:找出每一个员工对应的部门名称,以及
#该员工对应的工资等级。要求显示员工名、部门
#名、工资等级
#多张表进行连接的语法格式:
select 
        XXX
from
        a
join 
        b
on    
        条件
join 
         c
on
         条件;
原理:a和b连接,再用a和c连接。
select
e.ename,d.dname,s.grade
from
emp e
join
dept d
on
e.deptno=d.deptno;
join
salgrade s
on
e.sal between s.losal and s.hisal;
MySQL之表连接(内外连接和重命名的使用)的更多相关文章
- Mysql多表合并以及连接问题
		目的 1.为了备战过两天的面试,我又重新给孙老师的课件看了一遍,学累了,就写写自己的新的体会,和遇到的问题,来进行一个记录,这是知识产出的过程,据说可以帮助我学习,看视频什么的都是被动学习,不进行及时 ... 
- mysql数据库表间内外链接详解
		1. 内连接(自然连接) 2. 外连接 (1)左外连接 (左边的表不加限制)(2)右外连接(右边的表不加限制)(3)全外连接(左右两表都不加限制) 3. 自连接(同一张表内的连接) SQL的标准语法: ... 
- rac下asm管理的表空间-数据文件的重命名
		asm下表空间的重命名与普通文件系统下的表空间重命名原理是一样的,只不过asm管理的数据文件有一些需要注意的地方,另外在asm下操作数据文件需要格外小心,稍有不慎将会造成数据文件丢失,如可以做备份最好 ... 
- mysql,多表的内外连接+子查询
		表: student house course 关系:student_course 多对多 student house 多对一 需求:查询房间1 的学生 都学习了什么课程 select s.s_nam ... 
- 【mysql优化 3】嵌套循环连接算法
		原文地址:Nested-Loop Join Algorithms mysql在表之间执行连接操作,包括了使用循环嵌套算法或者其他在此基础上的变形. 循环嵌套连接算法: 一个简单的嵌套循环连接(NLJ: ... 
- mysql.user表中Host为%的含义
		百度搜: MySQL之权限管理(mysql.user表详解) 连接:http://blog.csdn.net/zmx729618/article/details/78026497 mysql.user ... 
- Mysql 库表操作初识
		Mysql 库表操作初识 终端登录mysql 这里只演示win下, cmd 终端. 至于怎么在win下, linux, mac安装, 感觉这是一个入门级的百度搜索问题, 安装都搞不定, 确实有点尴尬, ... 
- mysql数据库表的修改及删除
		一.对数据表的修改 1.重命名一张表: RENAME TABLE 原名 TO 新名字; ALTER TABLE 原名 RENAME 新名; ALTER TABLE 原名 RENAME TO 新名; 2 ... 
- ALTER语句重命名,重新定义和重新排序列
		该CHANGE,MODIFY和 ALTER子句可以改变现有列的名称和定义.他们有这些比较特征: CHANGE: 可以重命名列并更改其定义,或两者都可以. 具有更多的能力MODIFY,但是以某些操作的便 ... 
- MySQL 进阶6: 连接查询 (多表连接) : 等值连接/非等值连接 /左右全连接/内连接
		#进阶6: 连接查询 (多表连接) : 等值连接/非等值连接 /左右全连接/内连接 /* 含义: 当查询的字段来自于多个表时, 就会用到连接查询 一: sql 92标准 :等值连接 ,(#内连接) 1 ... 
随机推荐
- 7.19python昨日复习和多线程(2)
			2018-7-19 21:39:49 我觉得这次的笔记是非常非常完美的!!!明天继续 睡觉去啦! 傍黑时候和晴宝打电话,她特能说,很喜欢这种感觉,有好多东西要和你分享! 1.复习! # !/usr/b ... 
- centos6.9环境下JDK安装
			1.准备jdk安装文件: 这里我使用的是 jdk-7u79-linux-x64.tar.gz 2.在 /usr/local 目录下创建 sotfware目录,并上传JDK文件: 解压文件并修改文件夹为 ... 
- TFS二次开发05——下载文件(DownloadFile)
			前面介绍了怎样读取TFS上目录和文件的信息,怎么建立服务器和本地的映射(Mapping). 本节介绍怎样把TFS服务器上的文件下载到本地. 下载文件可以有两种方式: using Microsoft.T ... 
- 高并发服务器建议调小 TCP 协议的 time_wait 超时时间。
			1. [推荐]高并发服务器建议调小 TCP 协议的 time_wait 超时时间. 说明:操作系统默认 240 秒后,才会关闭处于 time_wait 状态的连接,在高并发访问下,服 务器端会因为处于 ... 
- Redis添加历史浏览记录
			参考资料 http://redisdoc.com/index.html http://redis-py.readthedocs.io/en/latest/#indices-and-tables 1.什 ... 
- python3爬虫-爬取新浪新闻首页所有新闻标题
			准备工作:安装requests和BeautifulSoup4.打开cmd,输入如下命令 pip install requests pip install BeautifulSoup4 打开我们要爬取的 ... 
- MySQL check table/optimize table/analyze table/REPAIR TABLE
			MySQL check table/optimize table/analyze table/REPAIR TABLE 转自:https://www.cnblogs.com/datastack/p/3 ... 
- gh-ost安装
			下载 : https://github.com/github/gh-ost/releases/tag/v1.0.28 先安装Go语言: sudo yum install golang 将gh-ost文 ... 
- 浅谈远程登录时,ssh的加密原理
			SSH:Secure Shell,是一种网络安全协议,主要用于登录远程计算机的加密过程. 登录方式主要有两种: 1.基于用户密码的登录方式: 加密原理: 当服务器知道用户请求登录时,服务器会把 ... 
- [LeetCode] 121. Best Time to Buy and Sell Stock_Easy tag: Dynamic Programming
			Say you have an array for which the ith element is the price of a given stock on day i. If you were ... 
