Datawhale MySQL 训练营 Task4 表联结

学习内容

  • MySQL别名
    • 列别名,将查询或者筛选出来列用AS 命名,如果有空格则需要引号 ''
    SELECT xxx AS xxxx
    FROM
    WHERE
    GROUP BY
    HAVING
    • 表别名, 把表起一个别名
    SELECT column_name(s)
    FROM table_name
    AS alias_name
    
  • JOIN 语句
-- JOIN: 如果表中有至少一个匹配,则返回行; 和INNRE JION 相同

SELECT column_name(s)
FROM table_name1
INNER JOIN table_name2 
ON table_name1.column_name=table_name2.column_name

-- LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行;会返回左表(table1)中所有的行
SELECT column_name(s)
FROM table_name1
LEFT JOIN table_name2 
ON table_name1.column_name=table_name2.column_name

-- RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行
SELECT column_name(s)
FROM table_name1
RIGHT JOIN table_name2 
ON table_name1.column_name=table_name2.column_name

-- FULL JOIN: 只要其中一个表中存在匹配,就返回行; 会从左右表中返回所有的行,不管左右匹不匹配
SELECT column_name(s)
FROM table_name1
FULL JOIN table_name2 
ON table_name1.column_name=table_name2.column_name

-- CROSS JOIN: 会把左右表个列相乘,返回N*M 的组合

用菜鸟教程里的几张图形象的表示出来

  • INNER JOIN: AB交集
    inner join
  • LEFT JOIN: A集
    left join
  • RIGHT JOIN: B集
    right join
  • FULL JOIN: AB并集

作业

  1. 项目五:组合两张表 (难度:简单)
    在数据库中创建表1和表2,并各插入三行数据(自己造)
    表1: Person
+-------------+---------+
| 列名         | 类型     |
+-------------+---------+
| PersonId    | int     |
| FirstName   | varchar |
| LastName    | varchar |
+-------------+---------+

PersonId 是上表主键

表2: Address

+-------------+---------+
| 列名         | 类型    |
+-------------+---------+
| AddressId   | int     |
| PersonId    | int     |
| City        | varchar |
| State       | varchar |
+-------------+---------+

AddressId 是上表主键

编写一个 SQL 查询,满足条件:无论 person 是否有地址信息,都需要基于上述两表提供 person 的以下信息:FirstName, LastName, City, State

-- 创建表
CREATE TABLE person(
PersonID int PRIMARY KEY,
FirstName varchar(20),
SecondName varchar(20)
);

INSERT INTO person VALUES(1,'Gali','Ma');
INSERT INTO person VALUES(2,'Yao','Xiao');
INSERT INTO person VALUES(3,'Tao','Baiwan');

CREATE TABLE address(
AddressId int PRIMARY KEY,
PersonId int,
City varchar(20),
State varchar(20)
);

INSERT INTO address VALUES(1,2,'Huangpu','Shanghai');
INSERT INTO address VALUES(2,1,'Huangpu','Shanghai');
INSERT INTO address VALUES(3,3,'Changsha','Hunan');
INSERT INTO address VALUES(4,4,'Haidian','Beijing');

SELECT Person.FirstName, Person.SecondName, Address.City,Address.State
FROM Person
LEFT JOIN Address
ON Person.PersonID = Address.PersonId

结果:

结果

  1. 项目六:删除重复的邮箱(难度:简单)
    编写一个 SQL 查询,来删除 email 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个。
+----+---------+
| Id | Email   |
+----+---------+
| 1  | a@b.com |
| 2  | c@d.com |
| 3  | a@b.com |
+----+---------+

Id 是这个表的主键。
例如,在运行你的查询语句之后,上面的 Email表应返回以下几行:

+----+------------------+
| Id | Email            |
+----+------------------+
| 1  | a@b.com |
| 2  | c@d.com  |
+----+------------------+

解答:

DELETE
FROM email
WHERE Id NOT IN (
  SELECT minId FROM
    (
   SELECT MIN(Id) as minId
   FROM email
   GROUP BY Email
     ) table_tmp
);

SELECT * FROM email;

My SQL 不能直接删除 You can't specify target table 'table name' for update in FROM clause; 所以需要加一个临时表,还需要给临时表和列起别名。

结果:

结果

参考

1.菜鸟教程-MySQL教程
2.W3SChool-SQL教程

转载于:https://www.cnblogs.com/sunchaothu/p/10460582.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值