MySQL笔记——多表查询

多表查询不能使用 SELECT * from emp, dept; 会产生笛卡尔积。
笛卡尔积,有A,B两个集合,A中有5条信息,B中有4条信息,那么查询结果就是5*4=20条

一、内连接查询

		-- 隐式内连接SELECT 字段列表 FROM 表1,表2,… WHERE 条件;例:select emp.name,emp.age,dept.dep_name from emp,dept where emp.dep_id = dept.id;可以给表起别名将上面的语句转换成下面这种。select t1.name,t1.age,t2.dep_name from emp t1,dept t2 where t1.dep_id = t2.id;

在这里插入图片描述

		-- 显示内连接SELECT 字段列表 FROM 表1 [INNER] JOIN 表2 ON 条件;如:select emp.name,dept.dep_name from emp inner join dept on emp.dep_id = dept.id;可以给表起别名将上面的语句转换成下面这种。select t1.name,t2.dep_name from emp t1 inner join dept t2 on t1.dep_id = t2.id;

在这里插入图片描述

二、外连接查询

		(1)左外连接:相当于查询A表所有数据和交集部分数据左外连接:SELECT 字段列表 FROM 表1 LEFT [OUTER] JOIN 表2 ON 条件;select * from emp left join dept on emp.dep_id = dept.id;

在这里插入图片描述

		(2)右外连接:相当于查询B表所有数据和交集部分数据右外连接:SELECT 字段列表 FROM 表1 RIGHT [OUTER] JOIN 表2 ON 条件;select * from emp right join dept on emp.dep_id = dept.id;

在这里插入图片描述

三、子查询

		(1)子查询概念查询中嵌套查询,称嵌套查询为子查询;(2)子查询根据查询结果不同,作用不同:①单行单列:作为条件值,使用 '='  '!='  '>'  '<'等进行条件判断SELECT 字段列表 FROM 表 WHERE 字段名 = (子查询);查询年龄大于周八的select * from emp where age>(select age from emp where name = '周八');

在这里插入图片描述

			②多行单列:作为条件值,使用in关键字进行条件判断SELECT 字段列表 FROM 表 WHERE 字段名 in (子查询);查询研发和销售的所有员工信息select * from emp where dep_id in (select id from dept where dep_name = '研发部' or dep_name = '销售部' );

在这里插入图片描述

			③多行多列:作为虚拟表SELECT 字段列表 FROM (子查询) WHERE 条件;-- 查询入职日期是‘1998-08-01’之后的员工信息和部门信息把(SELECT * from emp WHERE join_date>'1998-08-01')这个多行多列表作为虚拟表查询放到from后面SELECT * FROM (SELECT * from emp WHERE join_date>'1998-08-01') t1,dept WHERE t1.dep_id = dept.id;

在这里插入图片描述

四、练习

新建员工表,部门表,职务表,工资等级表
1.查询所有员工信息。查询员工编号id,员工姓名ename,工资salary,职务名称jname,职务描述description
2.查询员工编号,员工姓名,工资,职务名称,职务描述,部门名称,部门位置
3.查询员工姓名,工资,工资等级
4.查询员工姓名,工资,职务名称,职务描述,部门名称,部门位置,工资等级
5.查询出部门编号、部门名称、部门位置、部门人数具体步骤如下:首先新建四张表:
-- 部门表
CREATE TABLE dept ( id INT PRIMARY KEY auto_increment, -- 部门iddname VARCHAR ( 50 ), -- 部门名称loc VARCHAR ( 50 ) -- 部门所在地
);
-- 职务表,职务名称,职务描述
CREATE TABLE job ( id INT PRIMARY KEY,  -- 职务idjname VARCHAR ( 20 ),  -- 职务名称description VARCHAR ( 50 ) -- 职务描述
);
-- 员工表
CREATE TABLE emp (id INT PRIMARY KEY,-- 员工idename VARCHAR ( 50 ),-- 员工姓名job_id INT,-- 工作编号mgr INT,-- 上级领导joindate DATE,	-- 入职日期salary DECIMAL ( 7, 2 ),	-- 工资bonus DECIMAL ( 7, 2 ),-- 奖金dept_id INT,	-- 所在部门编号CONSTRAINT fk_emp_jobid_job_id FOREIGN KEY ( job_id ) REFERENCES job ( id ),CONSTRAINT fl_emp_deptid_dept_id FOREIGN KEY ( dept_id ) REFERENCES dept ( id ) 
);
-- 工资等级表
CREATE TABLE salarygrade ( grade INT PRIMARY KEY, -- 界别losalary INT, -- 最低工资hisalary INT -- 最高工资
);
添加数据:
-- 添加4个部门
INSERT INTO dept ( id, dname, loc )
VALUES( 10, '教研部', '北京' ),( 20, '学工部', '上海' ),( 30, '销售部', '广州' ),( 40, '财务部', '深圳' );
-- 添加4个职务
INSERT INTO job ( id, jname, description )
VALUES( 1, '董事长', '管理整个公司,接单' ),( 2, '经理', '管理部门员工' ),( 3, '销售员', '向客人推销产品' ),( 4, '文员', '使用办公软件' );
-- 添加员工
INSERT INTO emp ( id, ename, job_id, mgr, joindate, salary, bonus, dept_id )
VALUES( 1001, '孙悟空', 4, 1004, '2000-12-17', '8000.00', NULL, 20 ),( 1002, '卢俊义', 3, 1006, '2001-02-10', '16000.00', 3000.00, 30 ),( 1003, '林冲', 3, 1006, '2001-02-22', '12500.00', 5000.00, 30 ),( 1004, '唐僧', 2, 1009, '2001-04-02', '29750.00', NULL, 20 ),( 1005, '李逵', 4, 1006, '2001-09-17', '12500.00', 14000.00, 30 ),( 1006, '宋江', 2, 1009, '2001-05-17', '28500.00', NULL, 30 ),( 1007, '刘备', 2, 1009, '2001-09-17', '24500.00', NULL, 10 ),( 1008, '猪八戒', 4, 1004, '2007-12-17', '30000.00', NULL, 20 ),( 1009, '罗贯中', 1, NULL, '2000-12-17', '50000.00', NULL, 10 ),( 1010, '吴用', 3, 1006, '2001-09-17', '15000.00', '0.00', 30 ),( 1011, '沙僧', 4, 1004, '2007-05-17', '11000.00', NULL, 20 ),( 1012, '李逵', 4, 1006, '2001-12-03', '9500.00', NULL, 30 ),( 1013, '小白龙', 4, 1004, '2001-12-03', '30000.00', NULL, 20 ),( 1014, '关羽', 4, 1007, '2002-01-12', '13000.00', NULL, 10 );
-- 添加工资等级
INSERT INTO salarygrade ( grade, losalary, hisalary )
VALUES( 1, 7000, 12000 ),( 2, 12010, 14000 ),( 3, 14010, 20000 ),( 4, 20010, 30000 ),( 5, 30010, 99990 );
1.查询所有员工信息。查询员工编号id,员工姓名ename,工资salary,职务名称jname,职务描述description
-- 1.查询所有员工信息。查询员工编号id,员工姓名ename,工资salary,职务名称jname,职务描述description
/*
分析:
1.员工编号id,员工姓名ename,工资salary 在emp表中
2.职务名称jname,职务描述description,在职务表中
3.职务表和员工表是一对多的关系 e.job_id = j.id
通过内连接可完成
*/
-- 隐式内连接
SELECTemp.id,emp.ename,emp.salary,job.jname,job.description 
FROMemp,job 
WHEREemp.job_id = job.id;
-- 显示内连接
SELECTemp.id,emp.ename,emp.salary,job.jname,job.description 
FROMempINNER JOIN job ON emp.job_id = job.id;
2.查询员工编号,员工姓名,工资,职务名称,职务描述,部门名称,部门位置
-- 2.查询员工编号,员工姓名,工资,职务名称,职务描述,部门名称,部门位置
/*
分析:
1.员工编号,员工姓名,工资,在emp表中
2.职务名称,职务描述,在job表中
3.部门名称,部门位置,在dept表中
4.职务表和员工表是一对多的关系 e.job_id = j.id
5.部门表和员工表是一对多的关系 e.dept_id = d.id
*/
-- 隐式内连接
SELECTemp.id,emp.ename,emp.salary,job.jname,job.description,dept.dname,dept.loc 
FROMemp,job,dept 
WHEREemp.job_id = job.id AND emp.dept_id = dept.id;-- 显示内连接
SELECTemp.id,emp.ename,emp.salary,job.jname,job.description,dept.dname,dept.loc 
FROMempINNER JOIN job ON emp.job_id = job.idINNER JOIN dept ON emp.dept_id = dept.id;
3.查询员工姓名,工资,工资等级
-- 3.查询员工姓名,工资,工资等级
/*1.员工姓名,工资,emp2.工资等级,salarygrade3. salarygrade.losalary < emp.salary AND salarygrade.hisalary >  emp.salary
*/SELECTemp.ename,emp.salary,s.grade 
FROMemp,salarygrade s 
WHEREemp.salary >= s.losalary AND emp.salary <= s.hisalary;
4.查询员工姓名,工资,职务名称,职务描述,部门名称,部门位置,工资等级
-- 4.查询员工姓名,工资,职务名称,职务描述,部门名称,部门位置,工资等级
/*1.员工姓名,工资,emp2.职务名称,职务描述,job3.部门名称,部门位置,dept4.工资等级,salarygrade5.职务表和员工表是一对多的关系 e.job_id = j.id6.部门表和员工表是一对多的关系 e.dept_id = d.id7.salarygrade.losalary < emp.salary AND salarygrade.hisalary >  emp.salary
*/
-- 隐式内连接
SELECTemp.ename,emp.salary,job.jname,job.description,dept.dname,dept.loc,s.grade 
FROMemp,job,dept,salarygrade s 
WHEREemp.job_id = job.id AND emp.dept_id = dept.id AND emp.salary >= s.losalary AND emp.salary <= s.hisalary;-- 显式内连接	
SELECTemp.id,emp.ename,emp.salary,job.jname,job.description,dept.dname,dept.loc 
FROM
empINNER JOIN job ON emp.job_id = job.idINNER JOIN dept ON emp.dept_id = dept.idINNER JOIN salarygrade s ON emp.salary >= s.losalary AND emp.salary <= s.hisalary;
5.查询出部门编号、部门名称、部门位置、部门人数
-- 5.查询出部门编号、部门名称、部门位置、部门人数
/*1.部门编号、部门名称、部门位置,dept2.部门人数,按照dept_id,进行GROUP BY分组,count(*) 统计人数*/
-- 1.先在emp表中分组并统计人数,2.然后将1中产生的表作为子查询使用
SELECTdept.*,t1.total 
FROMdept,(SELECT dept_id, count( * ) total FROM emp GROUP BY dept_id ) t1 
WHEREt1.dept_id = dept.id;-- 第二种方法,先把员工和部门关联起来,然后按照部门id分组,并统计人数
SELECTcount( * ),t.* 
FROM( SELECT dept.* FROM emp, dept WHERE emp.dept_id = dept.id ) t 
GROUP BYt.id;

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

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

相关文章

遇见王沥川的人生感悟_23岁酱油泡饭默默无闻,31岁逆袭人生,王彦霖有何魅力?...

文/小白说娱S姐 原创精品&#xff0c;请勿转载如果兜里只剩下1块钱&#xff0c;生活所迫你会怎样过&#xff1f;王彦霖23岁刚毕业熬过了1元危机&#xff0c;他永远都不会想到当年咬牙坚持熬成就了如今的综艺诸葛。《元气满满的哥哥》连播六期多次排名第一&#xff0c;成为芒果台…

antd vue form 手动校验_参与《开课吧》vue训练营笔记(Day1)

大神说的目标&#xff1a;Vue 挑战20k组件间通信component 官网 详解组件间的传递方式&#xff1a;父传子 直接属性传递子传父 this.$emit 时间传递兄弟组件 利用父组件搭桥组件和子孙 provide / inject子孙 -> 祖先 this.$dispatch 或provide 获取组件元素实例$listeners $…

细学PHP 14 mysql-4

预留转载于:https://www.cnblogs.com/cnmice/archive/2013/04/17/3027102.html

Asterisk针对Mysql的extconfig.conf配置

Asterisk针对Mysql的extconfig.conf配置&#xff0c;这其中涉及到的表的structure [setting] sipusers > mysql,general,sip_buddies sippeers > mysql,general,sip_buddies queues > mysql,general,queue_table queue_members >mysql,general,queue_member_tabl…

ipfs 云服务器_IPFS加速云服务生机和分布式存储

如果能把一个安卓系统或IOS系统安装到分布式存储里&#xff0c;不管人们在做什么&#xff0c;各项数据都可以通过面部识别就可以确认ID&#xff0c;数据的响应性快&#xff0c;安全性和便捷性更高。IPFS的节点上&#xff0c;未来访问网站不再需要HTTP&#xff0c;而是IPFS。分布…

MySQL笔记——打开日志

在my.ini文件中输入如下命令&#xff1a;log_outputFILE general_logon general_log_file"D:\\SoftwareTools\\Mysql\\mysqllog\\mysql.log" slow_query_logon long_query_time 2 slow_query_log_file"D:\\SoftwareTools\\Mysql\\mysqllog\\mysql_slow.log"…

链表怎么输出最后一个元素无空格_剑指offer系列----从尾到头打印链表

从尾到头打印链表信息卡片时间&#xff1a;2020-03-23题目&#xff1a;从尾到头打印链表tag&#xff1a;list题目描述输入一个链表&#xff0c;按链表从尾到头的顺序返回一个 ArrayList。01调用 reverse 函数解题思路这是一种简单粗暴的解法。先遍历一遍链表&#xff0c;在遍历…

a20_v2.0_k70运行在xhda20开发板

修改sys_config.fex文件两个地方 [clock] pll3 297 pll4 300 pll6 600 pll7 297 pll8 336 [dram_para] dram_baseaddr 0x40000000 dram_clk 408 d…

EntiyFramework :Update model from database引起的两个问题

EntiyFramework一大特点就是Code first&#xff0c;但难免有时候因特殊原因需要Update model from database。此次使用该功能时遇到两个问题&#xff0c;且记之。 [问题一] Error 3027: No mapping specified for the following EntitySet/AssociationSet - XXXXXXX. [起因] 在…

MySQL笔记——JDBC入门

&#xff08;一&#xff09;JDBC简介 JDBC概念&#xff1a;&#xff08;1&#xff09;JDBC就是使用Java语言操作关系型数据库的一套API&#xff08;2&#xff09;全称&#xff1a;&#xff08;Java DataBase Connectivity&#xff09;Java数据库连接&#xff08;二&#xff09;…

python统计汉字个数是_Python中文词频统计

今天看到的一个统计&#xff0c;统计的金庸小说里面的高频词语。想着看了一周python&#xff0c;试试看能不能统计。 网上找的代码&#xff0c;调整顺序拼接了一下&#xff0c;分词库是结巴分词。 解决了python2.7中字典显示中文乱码的问题 分词代码&#xff1a;https://github…

cpu个数核数查看 服务器_服务器如何查看cpu核数

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":6,"count":6}]},"card":[{"des":"云服务器 ECS(Elastic Compute Service)是一…

SQL语句大全-珍藏首选

下列语句部分是Mssql语句&#xff0c;不可以在access中使用。 SQL分类&#xff1a; DDL—数据定义语言(CREATE&#xff0c;ALTER&#xff0c;DROP&#xff0c;DECLARE)   DML—数据操纵语言(SELECT&#xff0c;DELETE&#xff0c;UPDATE&#xff0c;INSERT)   DCL—数据控制…

Maven笔记——maven下载与配置

&#xff08;一&#xff09;Maven简介 Apache Maven是一个项目管理和构建的工具&#xff0c;它基于项目对象模型&#xff08;POM&#xff09;的概念。通过一小段描述信息来管理项目的构建&#xff0c;报告和文档。○ 项目对象模型○ 依赖管理模型○ 插件• 仓库分类&#xff1a…

Telerik Reporting之生成报表

本文为原创文&#xff0c;难免会有一些小得瑕疵&#xff0c;敬请谅解。所有示例均是博主测试过的&#xff0c;如有转载请标明出处&#xff0c;谢谢。第一步&#xff1a;建立一个普通类库。 第二步&#xff1a;在此类库中&#xff0c;新建项——Telerik Report报表。 第三步&…

python相对路径下的shell_shell,python获取当前路径(脚本的当前路径) (aso项目记录)...

一、shell获取脚本当前路径 cur_dir$(cd "$(dirname "$0")"; pwd) #获取当前脚本的绝对路径&#xff0c;参数$0是当前脚本对象 等同于cd dirname $0; pwd 但是&#xff0c;cd "dirname $0";pwd是错的&#xff0c;因为dirname不能用双引号 代码实…

spark 用户画像挖掘分析_如何基于Spark进行用户画像?

近期&#xff0c;comSysto公司分享了该公司研发团队利用Spark平台解决Kaggle竞赛问题的经历&#xff0c;为Spark等平台应用于数据科学领域提供了借鉴。主办方提供了一个包含5万个匿名驾驶员线路的数据集&#xff0c;竞赛的目的是根据路线研发出一个驾驶类型的算法类签名&#x…

Maven笔记——依赖管理

使用坐标导入jar包1) 在pom.xml中编写<dependencies>标签2) 在<dependencies>标签中使用<dependency>引入坐标3) 定义坐标的groupId、artifactId、version<dependencies><!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->…

ATL WTL 实现分析(五)

CDialogImpl 对话框本质上是布局和行为受约束的窗口。最原始的模态对话框API是&#xff1a; 1: WINUSERAPI2: INT_PTR3: WINAPI4: DialogBoxParamW(5: __in_opt HINSTANCE hInstance, //applicaton instance6: __in LPCWSTR lpTemplateName, //IDD : di…

python的read函数_Python Pandas pandas.read_sql函数方法的使用

pandas.read_sql&#xff08;sql&#xff0c;con&#xff0c;index_col None&#xff0c;coerce_float True&#xff0c;params None&#xff0c;parse_dates None&#xff0c;columns None&#xff0c;chunksize None)源代码 将SQL查询或数据库表读入DataFrame。 此功能…