MYSQL数据库实验三多表查询_数据库之 MySQL --- 数据处理 之多表查询 (三)

一、多表查询

【1】什么是多表查询?

即,从多个表中获取数据。

注意: 在多表查询是,如果列明在两个表中都有,那么列名前需要加上表名

sql优化:列名前最好加上表名,尤其在多表查询时

SELECT employees.`first_name`,employees.`department_id`

departments.`department_id`,departments.`department_name`

FROM employees,departments  -- 错误,缺少连接条件

-- 发生了笛卡尔集错误

-- 愿因: 缺少多表之间的连接条件,或者连接条件错误

SELECT e.first_name,e.department_id,-- 可以使用表的别名

d.department_id,d.department_name

FROM employees e, departments d -- 错误,缺少连接条件

【2】关于笛卡尔集 :

笛卡尔集会在下面条件下产生:

省略连接条件

连接条件无效

所有表中的所有行互相连接

为了避免笛卡尔集, 可以在 WHERE 加入有效的连接条件。

【3】使用笛卡尔集与不使用的对比

①查出所有数据

SELECT  * FROM employees

SELECT * FROM departments

②不使用笛卡尔集的普通子查询(MySQL连接)

在 WHERE 子句中写入连接条件。

在表中有相同列时,在列名之前加上表名前缀

-- 需求: 查询每个员工所在部门的名称

SELECT employees.`first_name`,employees.`department_id`,

departments.`department_id`,departments.`department_name`

FROM employees,departments

WHERE employees.`department_id`= departments.`department_id`

③使用JOIN ON 实现多表查询,解决笛卡尔集的问题

-- sq199规定了多表查询的规则

-- 使用 join on

-- 注意: 如果有n个表需要连表查询,那么至少得有n-12个连接条件

SELECT e.first_name,d.department_id,l.city

FROM employees e JOIN departments d

ON e.department_id = d.department_id

JOIN locations l

ON d.location_id = l.location_id

MySQL 连接

【1】自连接,非自链接

-- 自连接需求: 查找员工和员工的领导

SELECT e.first_name,m.first_name

FROM employees e JOIN employees m

ON e.`manager_id` = m.`employee_id`

-- 非自连接:两张不同的表进行连接查询

-- 等值连接,非等值连接

-- 等值连接案例

SELECT e.first_name,d.department_name

FROM employees e JOIN departments d

ON e.department_id = d.department_id

-- 非等值连接需求: 查看所有员工薪水的等级

SELECT e.first_name,e.`salary`,j.grade

FROM employees e JOIN job_grades j

ON e.`salary`>= j.lowest_sal AND e.`salary` <=j.highest_sal

【2】 内连接,外连接

-- 内连接:

合并具有同一列的两个以上的表的行,结果集中不包含一个表与另一个表不匹配的行

-- 外连接: 左外连接 VS 右外连接

-- 左外连接: 两个表在连接过程中除了返回满足连接条件的行以外还返回左表中不满足条件的行

-- 这种连接成为左外连接

SELECT  e.`first_name`,e.`department_id`,d.department_name

FROM employees e LEFT OUTER JOIN departments d

ON e.`department_id` = d.department_id

-- 右外连接:两个表在连接过程中除了返回满足连接条件的行意外还返回右表中不满足条件的行

-- 这种连接成为右外连接

SELECT e.`first_name`,e.`department_id`,d.department_id,d.department_name

FROM employees e RIGHT OUTER JOIN departments d

ON e.`department_id` = d.department_id

-- 满外连接 full join (mysql不支持)

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

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

相关文章

php mysql redis mq_docker 搭建 php-mysql-nginx-redis-rabbitmq环境

#创建redisdocker create -p 6379:6379 -v redis:/data --restartalways --name myredis redis#创建mysqldocker create --name mysql -p 3306:3306 -v mysql:/var/lib/mysql --restartalways -e MYSQL_ROOT_PASSWORDAbc123456 mysql:5.6 --character-set-serverutf8 --collati…

session mysql java_PHP自定义session处理方法,保存到MySQL数据库中

我们都知道&#xff0c;session是为了解决因特网的无状态属性而创造出来的。我们可以用session这种会话管理机制来构建购物车、监控站点网络访问&#xff0c;甚至还可以跟踪某一个用户具体是如何使用你的应用的。PHP默认的session处理行为已经能应付大部分的场景&#xff0c;但…

linux查看非注释行_Linux筛除空行和注释行的技巧

CentOS7.3学习笔记总结(四十一)- Linux筛除空行和注释行的技巧 在linux系统中的很多文件,写程序的人为了方便查阅整篇文档,写了很多注释,加了很多空行,虽然方便了整体的阅读,但是参数的添加、删除、修改等就没有那么友好了,我们就需要利用命令行筛选出没有这些内容的内容…

mysql数据迁移双写_数据迁移类测试策略

二、迁移类测试策略1、概述随着业务需求或数据量增长到一定程度&#xff0c;往往需要进行数据库切换&#xff0c;这里就伴随这数据迁移。关键字&#xff1a; 全量数据迁移&#xff0c;增量数据迁移&#xff0c;分库分表&#xff0c;数据双写&#xff0c;oracle、mysql、hbase……

python创建追加_Python文件的创建与追加

(转载)https://www.xshell.net/python/python_open.htmlPosted by 破冰 on 2013-9-17 17:29 Tuesday一、用Python创建一个新文件&#xff0c;内容是从0到9的整数, 每个数字占一行&#xff1a;#python>>>fopen(f.txt,w) # r只读&#xff0c;w可写&#xff0c;a追加&…

medoo update mysql_Medoo Update的使用:修改更新数据

update方法&#xff1a;update($table, $data,$where)&#xff0c;接受三个参数的传入&#xff0c;第三个可默认不传第一个需要传入的参数类型为字符串&#xff1a;String&#xff0c;即为要修改更新数据的数据表名第二个需要传入的参数类型为数组&#xff1a;array()&#xff…

vue限制只能输入数字_vue的input中,如何限制只能输入number

本来想用watch观察v-model的值&#xff0c;一旦不是数字&#xff0c;就让新值等于旧值&#xff0c;后来发现不行。h5的type”number”属性在手机上无效。有什么比较好的方法吗<input v-model"num">type”tel”的作用是直接弹出数字键盘吧&#xff0c;这样好像也…

where is null mysql_SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法

SET SQL SELECT * FROM Comment with(nolock) WHERE 11And (ProjectIds Is Null or ProjectId ProjectIds)And (Scores is null or Score Scores)印象中记得&#xff0c;以前在做Oracle开发时&#xff0c;这种写法是会导致全表扫描的&#xff0c;用不上索引&#xff0c;不知道…

lambda的java_一分钟搞明白java8中的lambda

项目结构是这样的User是一个普通的pojo类UserCompare是一个实现了Comprator的类现在我们有一个需求&#xff1a;给一个user组成的list 按照user的年龄排序。实现不难&#xff0c;代码如下&#xff1a;这种方法由于sort方法的第二个参数是Comparator 所以你要写一个实现类(我这里…

hash的算法 java_Java常用HASH算法总结【经典实例】

本文实例讲述了Java常用HASH算法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;/*** Hash算法大全* 推荐使用FNV1算法* algorithm None* author Goodzzp 2006-11-20* lastEdit Goodzzp 2006-11-20* editDetail Create*/public class HashAlgorithms{/**//*** 加法has…

读芯术python教程答案_攻略Python的免费书单:走进编程,从这五本书开始

全文共1245字&#xff0c;预计学习时长5分钟图源&#xff1a;unsplashPython一向是数据科学家最青睐的编程语言&#xff0c;它的语法相对简单、易于学习。除了机器学习数据库之外&#xff0c;还有非常活跃的开发人员社区&#xff0c;维护着各种库&#xff0c;用于数据分析、操作…

java的math类_Java之Math类使用小结

public classMain {public static voidmain(String[] args) {//TODO Auto-generated method stubSystem.out.println(Math.E);//比任何其他值都更接近 e(即自然对数的底数)的 double 值。System.out.println(Math.PI);//比任何其他值都更接近 pi(即圆的周长与直径之比)的 doubl…

java的复制构造函数_什么是Java中的复制构造函数?

通常&#xff0c;复制构造函数是通过使用先前已创建的相同类的对象初始化对象来创建对象的构造函数。Java支持复制构造函数&#xff0c;但与C语言不同&#xff0c;Java没有提供您需要自己定义的显式复制构造函数。写一个拷贝构造函数通常&#xff0c;为了初始化类的实例变量的值…

java对jsonarray去重复_java 去除jsonarray里面jsonarray的重复和合并数据

原来数据如下&#xff1a;[{"index_id":"19557485","itemid":"70575","time":"1467619020","value":"1"},{"index_id":"19557442","itemid":"113795&quo…

JAVA minaio模型_分布式系统之Java IO模型

1.正确理解IO定义IO涉及两个系统对象&#xff0c;一个是用户进程&#xff0c;一个是系统内核阻塞IO和非阻塞IO 针对是对用户进程来讲的调用函数。同步IO和异步IO针对的是系统内核。select,poll,epoll是Linux系统使用最多的IO多路复用机制&#xff0c;采用的都是同步IO。IO读取过…

算法导论 java版_《算法导论》第二章demo代码实现(Java版)

《算法导论》第二章demo代码实现(Java版)前言表示晚上心里有些不宁静&#xff0c;所以就写一篇博客&#xff0c;来缓缓。囧拜读《算法导论》这样的神作&#xff0c;当然要做一些练习啦。除了练习题与思考题那样的理论思考&#xff0c;也离不开编码的实践。所以&#xff0c;后面…

java js websocket_js+java websocket记录

首先websocket后台需要在web服务器运行&#xff0c;所以先搭建一个web项目。websocket需要依赖其他的jar包&#xff0c;引入依赖javaxjavaee-api7.0provided新建一个类&#xff0c;该类建立一个服务端点 ServerEndpointimportjavax.websocket.*;importjavax.websocket.server.P…

java 写一个计算器_java编写一个计算器类

展开全部import java.awt.BorderLayout;import java.awt.Color;import java.awt.GridLayout;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import javax.swing.ImageIcon;import javax.swing.JButton;import javax.swing.JFrame;import javax.swin…

java 移位运算效率_java 简单认识移位运算符和位运算符

移位运算符和位运算符本质上都是操作二进制位&#xff0c;因为计算机存储的是二进制数据&#xff0c;运算效率相对较高。移位运算符:把整数的二进制位进行左移或右移 .左移一位,相当于这个数乘以2, 右移一位,相当于这个数除以2/*移位运算符把整数的二进制位进行左移或右移按位左…

java文本框背景_用Java编写小程序(包含组合框下拉和文本框)变换背景颜色

展开全部代码如下&#xff1a;import java.awt.Color;import java.awt.Dimension;import java.awt.FlowLayout;import java.util.HashMap;import java.util.Map;import javax.swing.JComboBox;import javax.swing.JFrame;import javax.swing.JTextField;public class App exten…