- 查询语法:
select
列名列表
from
表名列表
where....
- 准备 sql
创建部门表
CREATE TABLE dept(
id INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(20)
);
INSERT INTO dept (NAME) VALUES ('开发部'),('市场部'),('财务部');
创建员工表
CREATE TABLE emp (
id INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(10),
gender CHAR(1), -- 性别
salary DOUBLE, -- 工资
join_date DATE, -- 入职日期
dept_id INT,
FOREIGN KEY (dept_id) REFERENCES dept(id) -- 外键,关联部门表(部门表的主键)
);
INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('孙悟空','男',7200,'2013-02-24',1);
INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('猪八戒','男',3600,'2010-12-02',2);
INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('唐僧','男',9000,'2008-08-08',2);
INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('白骨精','女',5000,'2015-10-07',3);
INSERT INTO emp(NAME,gender,salary,join_date,dept_id) VALUES('蜘蛛精','女',4500,'2011-03-14',1);
- 笛卡尔积:
- 有两个集合 A,B .取这两个集合的所有组成情况。
- 要完成多表查询,需要消除无用的数据
- 多表查询的分类:
- 内连接查询:
- 隐式内连接:使用 where 条件消除无用数据
- 例子:
- 隐式内连接:使用 where 条件消除无用数据
- 内连接查询:
-内连接查询:
- 从哪些表中查询数据
- 条件是什么
- 查询哪些字段
- 外链接查询:
- 左外连接:
- 语法:
select 字段列表 from 表 1 left [outer] join 表 2 on 条件; - 查询的是左表所有数据以及其交集部分。
- 例子:
- 语法:
- 左外连接:
- 子查询:
- 概念:查询中嵌套查询,称嵌套查询为子查询。
- 例子
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于