力扣数据库mysql 简单题
1.组合两张表
表: Person
+-------------+---------+ | 列名 | 类型 | +-------------+---------+ | PersonId | int | | FirstName | varchar | | LastName | varchar | +-------------+---------+
表: Address
+-------------+---------+ | 列名 | 类型 | +-------------+---------+ | AddressId | int | | PersonId | int | | City | varchar | | State | varchar | +-------------+---------+
SQL语句:
select Person.firstName,Person.lastName,Address.city,Address.state from Person LEFT JOIN Address on Person.personId = Address.personID;
上述语句是连续查询(交叉连接查询、内连接查询、外连接查询) 中的外连接:
举例:部门 员工表 黑马程序员例子
create table department(
did int(4) not null primary key,
danme varchar(36)
);
CREATE table employee(
id int(4) not null primary key,
name varchar(36),
age int(2),
did int(4) not null
)
insert into department values(1,'网络部'),(2,'媒体部'),(5,'人事部');
insert into employee values(1,'王红',20,1),(2,'李强',22,1),(3,'赵四',20,2),(4,'郝娟',20,4);
select * from department cross join employee;
表1的行数 * 表2的行数

内连接:
select employee.name,department.danme
from department join employee
on department.did = employee.did;
上述和where子句差不多
外连接:(左连接)
select department.did,department.danme,employee.name from department left JOIN
employee on department.did=employee.did;
外连接:(右连接)
select department.did,department.danme,employee.name from department right JOIN
employee on department.did=employee.did;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?