mysql表联结教程
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
作业
项目五:组合两张表 (难度:简单)
在数据库中创建表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
结果:
项目六:删除重复的邮箱(难度:简单)
编写一个 SQL 查询,来删除 email 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个。
±—±--------+
| Id | Email |
±—±--------+
| 1 | mailto:[email protected] |
| 2 | mailto:[email protected] |
| 3 | mailto:[email protected] |
±—±--------+
Id 是这个表的主键。
例如,在运行你的查询语句之后,上面的 Email表应返回以下几行:
±—±-----------------+
| Id | Email |
±—±-----------------+
| 1 | mailto:[email protected] |
| 2 | mailto:[email protected] |
±—±-----------------+
解答:
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; 所以需要加一个临时表,还需要给临时表和列起别名。
结果: