w3resource_MySQL练习题:Joins

1. Write a query to find the addresses (location_id, street_address, city, state_province, country_name) of all the departments
Hint : Use NATURAL JOIN.
Sample table: locations
Sample table: countries
-- 1. 自然连接,MySQL自己判断多表的连接条件,分为内/外自然连接
select location_id, street_address, city, state_province, country_name
from locations
NATURAL JOIN countries
-- 2. 多表连接,在from里连接多张表,通过where进行匹配
select l.location_id, l.street_address, l.city, l.state_province, c.country_name
from locations as l, countries as c
where l.country_id=c.country_id
2. Write a query to find the name (first_name, last name), department ID and name of all the employees
Sample table: employees
Sample table: departments
-- 1. 多表连接
select e.first_name, e.last_name, e.department_id, d.department_name
from employees as e, departments as d
where e.department_id=d.department_id
-- 2. 左连接(显然employees表数量远大于departments表)
select e.first_name, e.last_name, e.department_id, d.department_name
from employees as e
left join departments as d
on e.department_id=d.department_id

 

3. Write a query to find the name (first_name, last_name), job, department ID and name of the employees who works in London
Sample table: departments
Sample table: locations
-- 1. 多表连接
select e.first_name, e.last_name, e.job_id, e.department_id, d.department_name
from employees as e, departments as d, locations as l
where e.department_id=d.department_id
and d.location_id=l.location_id
and l.city='London'
-- 2. 左连接
select e.first_name, e.last_name, e.job_id, e.department_id, d.department_name
from employees as e
left join departments as d
on e.department_id=d.department_id
left join locations as l
on d.location_id=l.location_id
where l.city='London'
4. Write a query to find the employee id, name (last_name) along with their manager_id and name (last_name)
Sample table: employees
-- 1. 使用多表连接
select e1.employee_id, e1.last_name, e2.employee_id, e2.last_name
from employees as e1, employees as e2
where e1.manager_id=e2.employee_id
-- 2. 使用内连接
SELECT e.employee_id 'Emp_Id', e.last_name 'Employee',
m.employee_id 'Mgr_Id', m.last_name 'Manager'
FROM employees e
join employees m
ON (e.manager_id = m.employee_id);

  

5. Write a query to find the name (first_name, last_name) and hire date of the employees who was hired after 'Jones'
Sample table: employees
-- 1. 通过where进行筛选
select first_name, last_name, hire_date
from employees
where hire_date>(
    select hire_date from employees where last_name='Jones'
)
-- 2. 内连接
SELECT e.first_name, e.last_name, e.hire_date
FROM employees e
JOIN employees davies
ON (davies.last_name = 'Jones')
WHERE davies.hire_date < e.hire_date;
6. Write a query to get the department name and number of employees in the department
Sample table: employees
Sample table: departments
-- 要点:多表连接后,在新表做group by
select d.department_name, count(*)
from employees as e, departments as d
where e.department_id=d.department_id
group by e.department_id

  

7. Write a query to find the employee ID, job title, number of days between ending date and starting date for all jobs in department 90
Sample table: employees
-- 要点:datediff()
SELECT employee_id, j.job_title, DATEDIFF(end_date, start_date)
FROM job_history
NATURAL JOIN jobs AS j
WHERE department_id = 90;

  

8. Write a query to display the department ID and name and first name of manager
Sample table: employees
Sample table: departments
-- 要点:以departments表为左表
select d.department_id, d.department_name, e.first_name
from departments as d
left join employees as e
won d.manager_id=e.employee_id

  

9. Write a query to display the department name, manager name, and city
Sample table: employees
Sample table: departments
Sample table: locations
-- 要点:以departments表为主表
select d.department_name, e.first_name, l.city
from departments as d
left join employees as e
on d.manager_id=e.employee_id
left join locations as l
on d.location_id=l.location_id
10. Write a query to display the job title and average salary of employees
Sample table: employees
-- 要点:group by分组计算组内均值
select job_id, avg(salary)
from employees
group by job_id
11. Write a query to display job title, employee name, and the difference between salary of the employee and minimum salary for the job
Sample table: employees
-- 要点:多表连接
SELECT job_title, first_name, salary-min_salary 'Salary - Min_Salary'
FROM employees
NATURAL JOIN jobs;
12. Write a query to display the job history that were done by any employee who is currently drawing more than 10000 of salary
Sample table: employees
Sample table: Job_history
-- 要点:多表连接
select j.*
from job_history as j, employees as e
where j.employee_id=e.employee_id
and e.salary>10000

  

13. Write a query to display department name, name (first_name, last_name), hire date, salary of the manager for all managers whose experience is more than 15 years
Sample table: employees
Sample table: departments
-- 要点:datediff
select e.first_name, e.last_name, e.hire_date, e.salary, datediff(now(), (e.hire_date)) as exp
from departments as d, employees as e
where d.manager_id=e.employee_id
and datediff(now(), (e.hire_date))>15

w3resource_MySQL练习:Joins的更多相关文章

  1. SQL Tuning 基础概述07 - SQL Joins

    N多年之前,刚刚接触SQL的时候,就被多表查询中的各种内连接,外连接,左外连接,右外连接等各式各样的连接弄的晕头转向. 更坑的是书上看到的各种表连接还有两种不同的写法, 比如对于表A,表B的查询 1, ...

  2. Part 7 Joins in sql server

    Joins in sql server Advanced or intelligent joins in sql server Self join in sql server Different wa ...

  3. [HIve - LanguageManual] Joins

    Hive Joins Hive Joins Join Syntax Examples MapJoin Restrictions Join Optimization Predicate Pushdown ...

  4. 转载: C#: Left outer joins with LINQ

    I always considered Left Outer Join in LINQ to be complex until today when I had to use it in my app ...

  5. The dplyr package has been updated with new data manipulation commands for filters, joins and set operations.(转)

    dplyr 0.4.0 January 9, 2015 in Uncategorized I’m very pleased to announce that dplyr 0.4.0 is now av ...

  6. ### 七种SQL JOINS

    七种SQL JOINS 1.SELECT FROM TABLEA A LEFT JOIN TABLEB B ON A.Key=B.Key 2.SELECT FROM TABLEA A RIGHT JO ...

  7. MySQL Block Nested Loop and Batched Key Access Joins(块嵌套循环和批量Key访问连接)

    Block Nested-Loop and Batched Key Access Joins Batched Key Access (BKA) Join算法通过index和join buffer访问j ...

  8. MySQL表与表之间的SQL Joins图介绍

    下图很好的解释了各表之间SQL Joins之间的关系

  9. Lerning Entity Framework 6 ------ Joins and Left outer Joins

    Joins allow developers to combine data from multiple tables into a sigle query. Let's have a look at ...

随机推荐

  1. 不可见类有抽象父类,spring配置子类bean,注入父类,aop就可以切父类的方法

    public class TestBeanChild { int b = 1; public TestBean createDefault() { return new TestBeanDefault ...

  2. springboot集成log4j

    需求: 1.springboot集成log4j 2.mybatis 打印 sql 实现: pom.xml <dependency> <groupId>org.springfra ...

  3. 050 Pow(x, n)

    实现 pow(x, n).示例 1:输入: 2.00000, 10输出: 1024.00000示例 2:输入: 2.10000, 3输出: 9.26100详见:https://leetcode.com ...

  4. 升级到spring security5遇到的坑-密码存储格式

    遇到的问题 将spring security oauth2(包括spring security)升级到最新,代码没有改动,运行项目没有报错,但是页面登陆时报错:There is no Password ...

  5. 3.Freshman阶段学习内容的确定

    我刷知乎.在知乎上答题的程序员,不是很牛逼就是更牛逼,说起各种系统.各种系统的各种版本.各种语言.数据库.算法.IT届的各种圣战都有板有眼.信手拈来.头头是道,不得不服.这导致了一些非常严重的问题:我 ...

  6. ArcGIS Server 10.1发布GP服务

    ArcGIS Server 10.1发布GP服务 ArcGIS Server 10.1发布GP服务确实更简单了,只是刚使用不怎么习惯.ArcGIS Server 10.1发布GP服务需要先在ArcCa ...

  7. 总结jboss控制台,得出一下结论(数据库连接池相关)

    jboss控制台中: http://127.0.0.1:8080/jmx-console/HtmlAdaptor?action=inspectMBean&name=jboss.jca%3Ase ...

  8. 两个div并列居中显示——当display:inline;时,div的宽高不起作用即两个div重叠显示

    解决办法: 将display设置为:inline-block

  9. pre-empting taskintel手册-Chapter7-Task Management

    这节描述了IA-32架构的任务管理功能,只有当处理器运行在保护模式的时候,这个功能才是有效的,这节的侧重点在32位任务和32位TSS结构上,关于16位的任务和16位TSS结构,请看7.6节,关于64位 ...

  10. HDU 1007 Quoit Design最近点对( 分治法)

    题意: 给出平面上的n个点,问任意点对之间的最短距离是多少? 思路: 先将所有点按照x坐标排序,用二分法将n个点一分为二个部分,递归下去直到剩下两或一个点.对于一个部分,左右部分的答案分别都知道,那么 ...