时间:2021-07-01 10:21:17 帮助过:6人阅读
1 多表查询 2 一 简单查询 多张表 提取相同的 假设department id 和 employee dep_id 关联 3 1.1 select * from department,employee; 结果显示一张表上,是左右字段一次排开拼接这种 4 遍历第一张表,循环第二张,配对一遍,显示出来,拼接方式叫做 笛卡尔积 5 select * from department,employee where department.id=employee.dep_id; 6 select * from employee,department where department.id=employee.dep_id; 提取2表相同的部分 7 8 9 二 连表操作 10 2.1 内链接 inner join department on 11 按照on条件只取2表的相同部分,链接成一张虚拟的表 12 select * from employee inner join department on department.id=employee.dep_id; 提取2表相同的部分 13 14 2.2 左链接 left join department on 15 按照on条件取2表的相同部分基础上,保留左表有,右边没有的记录 16 select * from employee left join department on department.id=employee.dep_id; 17 18 2.3 右链接 right join department on 19 按照on条件取2表的相同部分基础上,保留右表有,左边没有的记录 20 select * from employee right join department on department.id=employee.dep_id; 21 22 2.4 全链接 full join 在mysql里面没有这个功能,只是个概念,还要考左,右链接拼凑出来 23 有对应关系,和没对应关系的都取出来 24 select * from employee left join department on department.id=employee.dep_id 25 union 联合的意思,将2表联合,去掉重复的部分 26 select * from employee right join department on department.id=employee.dep_id; 27 28 ** 优先级 29 from > join on 后面的条件联合 > where > gourp by > 聚合 > having > order by > limit > select 30 31 三 子查询 32 3.1 带in关键字的子查询 33 select id from department where name in (‘技术‘,‘销售‘); 查看2个部门的d 34 select * from employee where dep_id in (200.202); 查询部门id对应的员工 35 问题;怎么知道员工的id,应该是从部门表得到id 36 select * from employee where dep_id in (select id from department where name in (‘技术‘,‘销售‘)); 37 38 3.2 练习 39 1. 查询平均年龄在25岁以上的部门名 40 select name from department where id in (select dep_id from employee group by dep_id having avg(age) > 25); 41 2. 查看技术部员工姓名 42 select name from employee where dep_id in (select id from department where name=‘技术‘); 43 3. 查看人数小于2的部门,不准确,因为还有空的存在,看 4 5 题 44 select name from department where id in (select dep_id from employee group by dep_id having count(dep_id) < 2); 45 4. 提取空部门,就是没有人的部门 46 select distinct dep_id from employee; 去重,有人的部门 47 select name from department where id not in (select distinct dep_id from employee); 非有人的部门,空部门 48 5. 查看人数小于2的部门,但是有空的情况 49 select name from department where id in (select dep_id from employee group by dep_id having count(dep_id) < 2) 50 union 51 select name from department where id not in (select distinct dep_id from employee); 没有人的部门 52 53 或者: 54 select name from department where id in 55 ( 56 select dep_id from employee group by dep_id having count(id) < 2 57 union 58 select id from department where id not in (select distinct dep_id from employee) 59 ); 60 61 3.3 exists存在,判断 62 select * from employee where exists (select id from department where name=‘技术‘); 63 select id from department where name=‘技术‘ 存在 就打印前面的select,不存在就返回空 64 65 ** 子查询,括号内的查询都要select出2表相同的字段,这样才可以,语法:查询 where 相同字段 in 子查询
1 总结; 2 查询语法 3 SELECT 字段1,字段2... FROM 表名 4 JOIN ON 5 WHERE 条件 6 GROUP BY field 7 HAVING 筛选 8 ORDER BY field 9 LIMIT 限制条数 10 11 关键字的执行优先级 12 from 13 join on 14 where 15 --------------- 16 group by 17 --------------- 18 聚合 19 having 20 select 21 --------------- 22 限制打印 23 distinct 24 order by 25 limit
1 #创建表 2 create table employee( 3 id int not null unique auto_increment, 4 name varchar(20) not null, 5 sex enum(‘male‘,‘female‘) not null default ‘male‘, #大部分是男的 6 age int(3) unsigned not null default 28, 7 hire_date date not null, 8 post varchar(50), 9 post_comment varchar(100), 10 salary double(15,2), 11 office int, #一个部门一个屋子 12 depart_id int 13 ); 14 15 #插入记录 16 #三个部门:教学,销售,运营 17 insert into employee(name,sex,age,hire_date,post,salary,office,depart_id) values 18 (‘egon‘,‘male‘,18,‘20170301‘,‘老男孩驻沙河办事处外交大使‘,7300.33,401,1), #以下是教学部 19 (‘alex‘,‘male‘,78,‘20150302‘,‘teacher‘,1000000.31,401,1), 20 (‘wupeiqi‘,‘male‘,81,‘20130305‘,‘teacher‘,8300,401,1), 21 (‘yuanhao‘,‘male‘,73,‘20140701‘,‘teacher‘,3500,401,1), 22 (‘liwenzhou‘,‘male‘,28,‘20121101‘,‘teacher‘,2100,401,1), 23 (‘jingliyang‘,‘female‘,18,‘20110211‘,‘teacher‘,9000,401,1), 24 (‘jinxin‘,‘male‘,18,‘19000301‘,‘teacher‘,30000,401,1), 25 (‘成龙‘,‘male‘,48,‘20101111‘,‘teacher‘,10000,401,1), 26 27 (‘歪歪‘,‘female‘,48,‘20150311‘,‘sale‘,3000.13,402,2),#以下是销售部门 28 (‘丫丫‘,‘female‘,38,‘20101101‘,‘sale‘,2000.35,402,2), 29 (‘丁丁‘,‘female‘,18,‘20110312‘,‘sale‘,1000.37,402,2), 30 (‘星星‘,‘female‘,18,‘20160513‘,‘sale‘,3000.29,402,2), 31 (‘格格‘,‘female‘,28,‘20170127‘,‘sale‘,4000.33,402,2), 32 33 (‘张野‘,‘male‘,28,‘20160311‘,‘operation‘,10000.13,403,3), #以下是运营部门 34 (‘程咬金‘,‘male‘,18,‘19970312‘,‘operation‘,20000,403,3), 35 (‘程咬银‘,‘female‘,18,‘20130311‘,‘operation‘,19000,403,3), 36 (‘程咬铜‘,‘male‘,18,‘20150411‘,‘operation‘,18000,403,3), 37 (‘程咬铁‘,‘female‘,18,‘20140512‘,‘operation‘,17000,403,3) 38 ;
1 多表查询 2 整体是一个数据,方便管理,节省空间拆成不同的表 3 company.employee 4 company.department 5 6 ==============================被关联表 7 创建 被关联表 8 create table department( 9 id int, 10 name varchar(20) 11 )charset utf8; 12 插入数据 13 insert into department values 14 (200,‘技术‘), 15 (201,‘人力资源‘), 16 (202,‘销售‘), 17 (203,‘运营‘); 18 19 20 ===============================关联表 21 创建 关联表 22 create table employee( 23 id int primary key auto_increment, 24 name varchar(20), 25 sex enum(‘male‘,‘female‘) not null default ‘male‘, 26 age int, 27 dep_id int 28 )charset utf8; 29 插入数据 30 insert into employee(name,sex,age,dep_id) values 31 (‘egon‘,‘male‘,18,200), 32 (‘alex‘,‘female‘,48,201), 33 (‘wupeiqi‘,‘male‘,38,201), 34 (‘yuanhao‘,‘female‘,28,202), 35 (‘liwenzhou‘,‘male‘,18,200), 36 (‘jingliyang‘,‘female‘,18,204) 37 ; 38 39 ** 暂时不加入外键,如果假如外键,关联表在拆入数据的时候,插入204,上面的表没有下面的表对应关系 40 上有下没有,下有上没有,就会报错 41 上表有203下面没有,下面204上面没有 42 ** 虽然没有外键,咱们假设department id 和 employee dep_id 关联
python开发mysql:单表查询&多表查询
标签:asc bsp 应该 esc reg 重复 des 资源 关联表