mysql数据库优化课程---12、mysql嵌套和链接查询(查询user表中存在的所有班级的信息?)...
mysql数据库优化课程---12、mysql嵌套和链接查询(查询user表中存在的所有班级的信息?)
一、总结
一句话总结:
in:distinct:select * from class where id in(select distinct class_id from user);
mysql> select * from class where id in(select distinct class_id from user);
+----+--------+------------+
| id | name | ctime |
+----+--------+------------+
| 1 | class1 | 1492086867 |
| 2 | class2 | 1492086867 |
| 3 | class3 | 1492086867 |
+----+--------+------------+
2、查询班级表中每个班的所有学员信息?
mysql> select * from user where class_id in(select id from class);
+----+----------+-----+----------+
| id | username | age | class_id |
+----+----------+-----+----------+
| 1 | user1 | 19 | 1 |
| 2 | user2 | 19 | 1 |
| 3 | user3 | 19 | 1 |
| 4 | user4 | 19 | 1 |
| 5 | user5 | 19 | 2 |
| 6 | user6 | 19 | 3 |
| 7 | user7 | 19 | 2 |
| 8 | user8 | 19 | 1 |
| 9 | user9 | 19 | 2 |
| 10 | user10 | 19 | 3 |
| 11 | user10 | 19 | 4 |
+----+----------+-----+----------+
3、嵌套查询为什么用的少?
因为嵌套查询能做到的普通多表查询和链接查询一般都能做到
4、请统计每个班的总人数?
错误答案:select class_id,count(*) from user group by class_id;
left join:select class.name,count(user.id) tot from class left join user on class.id=user.class_id group by class.id;
right join:select class.name,count(user.id) tot from user right join class on class.id=user.class_id group by class.id;
需求6:请统计每个班的总人数?
1)错误答案
mysql> select class_id,count(*) from user group by class_id;
+----------+----------+
| class_id | count(*) |
+----------+----------+
| 1 | 5 |
| 2 | 3 |
| 3 | 2 |
+----------+----------+
2)正确答案
mysql> select class.name,count(user.id) tot from class left join user on class.id=user.class_id group by class.id;
+--------+-----+
| name | tot |
+--------+-----+
| class1 | 5 |
| class2 | 3 |
| class3 | 2 |
| class4 | 0 |
+--------+-----+
3)正确答案
mysql> select class.name,count(user.id) tot from user right join class on class.id=user.class_id group by class.id;
+--------+-----+
| name | tot |
+--------+-----+
| class1 | 5 |
| class2 | 3 |
| class3 | 2 |
| class4 | 0 |
+--------+-----+
5、嵌套查询和索引的关系?
嵌套查询里面或者外面的索引会失效,所以嵌套查询没有链接查询速度快
6、count(id)的用处在哪?
left连接之后统计班级人数,就是这个class4的0人,这里用count(*)就不行
需求6:请统计每个班的总人数?
mysql> select class.name,count(user.id) tot from class left join user on class.id=user.class_id group by class.id;
+--------+-----+
| name | tot |
+--------+-----+
| class1 | 5 |
| class2 | 3 |
| class3 | 2 |
| class4 | 0 |
+--------+-----+
7、链接查询的条件字段是什么?
on:select class.name,count(user.id) tot from class left join user on class.id=user.class_id group by class.id;
需求6:请统计每个班的总人数?
mysql> select class.name,count(user.id) tot from class left join user on class.id=user.class_id group by class.id;
+--------+-----+
| name | tot |
+--------+-----+
| class1 | 5 |
| class2 | 3 |
| class3 | 2 |
| class4 | 0 |
+--------+-----+
8、链接查询和普通多表查询的区别是什么(查询每个用户的用户名和对应的班级名称)?
内链接:select user.username,class.name from user inner join class on class.id=user.class_id;
普通多表查询:select user.username,class.name from user,class where user.class_id=class.id;
需求7: 查询每个用户的用户名和对应的班级名称?
1)正确答案(内链接)
mysql> select user.username,class.name from user inner join class on class.id=user.class_id;
+----------+--------+
| username | name |
+----------+--------+
| user1 | class1 |
| user2 | class1 |
| user3 | class1 |
| user4 | class1 |
| user5 | class2 |
| user6 | class3 |
| user7 | class2 |
| user8 | class1 |
| user9 | class2 |
| user10 | class3 |
+----------+--------+
2)正确答案(普通多表查询)
mysql> select user.username,class.name from user,class where user.class_id=class.id;
+----------+--------+
| username | name |
+----------+--------+
| user1 | class1 |
| user2 | class1 |
| user3 | class1 |
| user4 | class1 |
| user5 | class2 |
| user6 | class3 |
| user7 | class2 |
| user8 | class1 |
| user9 | class2 |
| user10 | class3 |
+----------+--------+
二、内容在总结中
mysql多表查询:
1.普通多表查询
2.嵌套查询或子查询
3.链接查询
1)左链接
2)右链接
3)内链接
查看class表数据:
mysql> select * from class;
+----+--------+------------+
| id | name | ctime |
+----+--------+------------+
| 1 | class1 | 1492086867 |
| 2 | class2 | 1492086867 |
| 3 | class3 | 1492086867 |
+----+--------+------------+
查看user表数据:
mysql> select * from user;
+----+----------+-----+
| id | username | age |
+----+----------+-----+
| 1 | user1 | 19 |
| 2 | user2 | 29 |
| 3 | user3 | 31 |
| 4 | user4 | 22 |
| 5 | user5 | 23 |
| 6 | user6 | 18 |
| 7 | user7 | 17 |
| 8 | user8 | 25 |
| 9 | user9 | 27 |
| 10 | user10 | 32 |
+----+----------+-----+
两表无条件查询:
mysql> select * from class,user;
+----+--------+------------+----+----------+-----+
| id | name | ctime | id | username | age |
+----+--------+------------+----+----------+-----+
| 1 | class1 | 1492086867 | 1 | user1 | 19 |
| 2 | class2 | 1492086867 | 1 | user1 | 19 |
| 3 | class3 | 1492086867 | 1 | user1 | 19 |
| 4 | class4 | 1492087405 | 1 | user1 | 19 |
| 1 | class1 | 1492086867 | 2 | user2 | 29 |
| 2 | class2 | 1492086867 | 2 | user2 | 29 |
| 3 | class3 | 1492086867 | 2 | user2 | 29 |
| 4 | class4 | 1492087405 | 2 | user2 | 29 |
| 1 | class1 | 1492086867 | 3 | user3 | 31 |
| 2 | class2 | 1492086867 | 3 | user3 | 31 |
| 3 | class3 | 1492086867 | 3 | user3 | 31 |
| 4 | class4 | 1492087405 | 3 | user3 | 31 |
| 1 | class1 | 1492086867 | 4 | user4 | 22 |
| 2 | class2 | 1492086867 | 4 | user4 | 22 |
| 3 | class3 | 1492086867 | 4 | user4 | 22 |
| 4 | class4 | 1492087405 | 4 | user4 | 22 |
| 1 | class1 | 1492086867 | 5 | user5 | 23 |
| 2 | class2 | 1492086867 | 5 | user5 | 23 |
| 3 | class3 | 1492086867 | 5 | user5 | 23 |
| 4 | class4 | 1492087405 | 5 | user5 | 23 |
| 1 | class1 | 1492086867 | 6 | user6 | 18 |
| 2 | class2 | 1492086867 | 6 | user6 | 18 |
| 3 | class3 | 1492086867 | 6 | user6 | 18 |
| 4 | class4 | 1492087405 | 6 | user6 | 18 |
| 1 | class1 | 1492086867 | 7 | user7 | 17 |
| 2 | class2 | 1492086867 | 7 | user7 | 17 |
| 3 | class3 | 1492086867 | 7 | user7 | 17 |
| 4 | class4 | 1492087405 | 7 | user7 | 17 |
| 1 | class1 | 1492086867 | 8 | user8 | 25 |
| 2 | class2 | 1492086867 | 8 | user8 | 25 |
| 3 | class3 | 1492086867 | 8 | user8 | 25 |
| 4 | class4 | 1492087405 | 8 | user8 | 25 |
| 1 | class1 | 1492086867 | 9 | user9 | 27 |
| 2 | class2 | 1492086867 | 9 | user9 | 27 |
| 3 | class3 | 1492086867 | 9 | user9 | 27 |
| 4 | class4 | 1492087405 | 9 | user9 | 27 |
| 1 | class1 | 1492086867 | 10 | user10 | 32 |
| 2 | class2 | 1492086867 | 10 | user10 | 32 |
| 3 | class3 | 1492086867 | 10 | user10 | 32 |
| 4 | class4 | 1492087405 | 10 | user10 | 32 |
+----+--------+------------+----+----------+-----+
结论:
1.两表数据进行所有组合.
2.数据量是两表条数乘积.
设计了关系的user表:
mysql> select * from user;
+----+----------+-----+----------+
| id | username | age | class_id |
+----+----------+-----+----------+
| 1 | user1 | 19 | 1 |
| 2 | user2 | 19 | 1 |
| 3 | user3 | 19 | 1 |
| 4 | user4 | 19 | 1 |
| 5 | user5 | 19 | 2 |
| 6 | user6 | 19 | 3 |
| 7 | user7 | 19 | 2 |
| 8 | user8 | 19 | 1 |
| 9 | user9 | 19 | 2 |
| 10 | user10 | 19 | 3 |
+----+----------+-----+----------+
需求1:请查询出每一个学员的姓名、年龄、班级名称和班级创建时间?
mysql> select user.username,user.age,class.name,class.ctime from user,class where user.class_id=class.id;
+----------+-----+--------+------------+
| username | age | name | ctime |
+----------+-----+--------+------------+
| user1 | 19 | class1 | 1492086867 |
| user2 | 19 | class1 | 1492086867 |
| user3 | 19 | class1 | 1492086867 |
| user4 | 19 | class1 | 1492086867 |
| user5 | 19 | class2 | 1492086867 |
| user6 | 19 | class3 | 1492086867 |
| user7 | 19 | class2 | 1492086867 |
| user8 | 19 | class1 | 1492086867 |
| user9 | 19 | class2 | 1492086867 |
| user10 | 19 | class3 | 1492086867 |
+----------+-----+--------+------------+
需求2:请查询出每一个学员的姓名、年龄、班级名称和班级创建时间,并把时间戳转成正常日期显示出来?
mysql> select user.username,user.age,class.name,from_unixtime(class.ctime) ctime from user,class where user.class_id=class.id;
+----------+-----+--------+---------------------+
| username | age | name | ctime |
+----------+-----+--------+---------------------+
| user1 | 19 | class1 | 2017-04-13 20:34:27 |
| user2 | 19 | class1 | 2017-04-13 20:34:27 |
| user3 | 19 | class1 | 2017-04-13 20:34:27 |
| user4 | 19 | class1 | 2017-04-13 20:34:27 |
| user5 | 19 | class2 | 2017-04-13 20:34:27 |
| user6 | 19 | class3 | 2017-04-13 20:34:27 |
| user7 | 19 | class2 | 2017-04-13 20:34:27 |
| user8 | 19 | class1 | 2017-04-13 20:34:27 |
| user9 | 19 | class2 | 2017-04-13 20:34:27 |
| user10 | 19 | class3 | 2017-04-13 20:34:27 |
+----------+-----+--------+---------------------+
需求3:请查询出每一个学员的姓名、年龄、班级名称和班级创建时间,并且只查询1班学员?
mysql> select user.username,user.age,class.name,class.ctime from user,class where user.class_id=class.id and class.id=1;
+----------+-----+--------+------------+
| username | age | name | ctime |
+----------+-----+--------+------------+
| user1 | 19 | class1 | 1492086867 |
| user2 | 19 | class1 | 1492086867 |
| user3 | 19 | class1 | 1492086867 |
| user4 | 19 | class1 | 1492086867 |
| user8 | 19 | class1 | 1492086867 |
+----------+-----+--------+------------+
需求4:查询user表中存在的所有班级的信息?
mysql> select * from class where id in(select distinct class_id from user);
+----+--------+------------+
| id | name | ctime |
+----+--------+------------+
| 1 | class1 | 1492086867 |
| 2 | class2 | 1492086867 |
| 3 | class3 | 1492086867 |
+----+--------+------------+
需求5:查询班级表中每个班的所有学员信息?
mysql> select * from user where class_id in(select id from class);
+----+----------+-----+----------+
| id | username | age | class_id |
+----+----------+-----+----------+
| 1 | user1 | 19 | 1 |
| 2 | user2 | 19 | 1 |
| 3 | user3 | 19 | 1 |
| 4 | user4 | 19 | 1 |
| 5 | user5 | 19 | 2 |
| 6 | user6 | 19 | 3 |
| 7 | user7 | 19 | 2 |
| 8 | user8 | 19 | 1 |
| 9 | user9 | 19 | 2 |
| 10 | user10 | 19 | 3 |
| 11 | user10 | 19 | 4 |
+----+----------+-----+----------+
左链接:
需求6:请统计每个班的总人数?
1)错误答案
mysql> select class_id,count(*) from user group by class_id;
+----------+----------+
| class_id | count(*) |
+----------+----------+
| 1 | 5 |
| 2 | 3 |
| 3 | 2 |
+----------+----------+
2)正确答案
mysql> select class.name,count(user.id) tot from class left join user on class.id=user.class_id group by class.id;
+--------+-----+
| name | tot |
+--------+-----+
| class1 | 5 |
| class2 | 3 |
| class3 | 2 |
| class4 | 0 |
+--------+-----+
3)正确答案
mysql> select class.name,count(user.id) tot from user right join class on class.id=user.class_id group by class.id;
+--------+-----+
| name | tot |
+--------+-----+
| class1 | 5 |
| class2 | 3 |
| class3 | 2 |
| class4 | 0 |
+--------+-----+
需求7: 查询每个用户的用户名和对应的班级名称?
1)正确答案(内链接)
mysql> select user.username,class.name from user inner join class on class.id=user.class_id;
+----------+--------+
| username | name |
+----------+--------+
| user1 | class1 |
| user2 | class1 |
| user3 | class1 |
| user4 | class1 |
| user5 | class2 |
| user6 | class3 |
| user7 | class2 |
| user8 | class1 |
| user9 | class2 |
| user10 | class3 |
+----------+--------+
2)正确答案(普通多表查询)
mysql> select user.username,class.name from user,class where user.class_id=class.id;
+----------+--------+
| username | name |
+----------+--------+
| user1 | class1 |
| user2 | class1 |
| user3 | class1 |
| user4 | class1 |
| user5 | class2 |
| user6 | class3 |
| user7 | class2 |
| user8 | class1 |
| user9 | class2 |
| user10 | class3 |
+----------+--------+
转载于:https://www.cnblogs.com/Renyi-Fan/p/9806861.html
mysql数据库优化课程---12、mysql嵌套和链接查询(查询user表中存在的所有班级的信息?)...相关推荐
- mysql所有班级名称和人数_mysql数据库优化课程---12、mysql嵌套和链接查询(查询user表中存在的所有班级的信息?)...
mysql数据库优化课程---12.mysql嵌套和链接查询(查询user表中存在的所有班级的信息?) 一.总结 一句话总结: in:distinct:select * from class wher ...
- mysql数据库优化课程---16、mysql慢查询和优化表空间
mysql数据库优化课程---16.mysql慢查询和优化表空间 一.总结 一句话总结: a.慢查询的话找到存储慢查询的那个日志文件 b.优化表空间的话可以用optimize table sales; ...
- mysql数据库优化课程---15、mysql优化步骤(mysql中最常用最立竿见影的优化是什么)...
mysql数据库优化课程---15.mysql优化步骤(mysql中最常用最立竿见影的优化是什么) 一.总结 一句话总结:索引优化最立竿见影 索引优化:不然有多少行要扫描多少次,1亿行大概是5到10分 ...
- mysql数据库优化课程---6、mysql结构化查询语言有哪些
mysql数据库优化课程---6.mysql结构化查询语言有哪些 一.总结 一句话总结:主要分为四类 1.DCL 数据控制语言 1)grant 2)commit 3)rollback 2.DDL 数据 ...
- mysql数据库优化课程---13、mysql基础操作
mysql数据库优化课程---13.mysql基础操作 一.总结 一句话总结:mysql复制表,索引,视图 1.mysql如何复制表? like select * 1.复制表结构 create tab ...
- linux mysql数据库优化_MySQL_Linux下MySQL数据库性能调优方法,以下的环境具备一定的代表性 - phpStudy...
Linux下MySQL数据库性能调优方法 以下的环境具备一定的代表性,可以说是中小企业一般配置和工作环境.希望通过本文能让大家理解Linux下MySQL数据库性能调优方法. 硬件准备环境: 硬盘: 1 ...
- mysql数据库优化大全_MySQL数据库优化技巧大全
简介: MySQL数据库优化技巧大全 MySQL优化三大方向 ① 优化MySQL所在服务器内核(此优化一般由运维人员完成). ② 对MySQL配置参数进行优化(my.cnf)此优化需要进行压力测试来进 ...
- MySQL数据库优化技巧大全
简介:MySQL数据库优化技巧大全 MySQL优化三大方向 ① 优化MySQL所在服务器内核(此优化一般由运维人员完成). ② 对MySQL配置参数进行优化(my.cnf)此优化需要进行压力测试来进行 ...
- 物联网 mysql数据库优化_MySQL数据库优化大全方法汇总-阿里云开发者社区
随着数据和负载增加,MySQL数据库会日渐缓慢,性能越来越差,用户体验也随之变差,所以数据库性能优化十分紧迫,云吞铺子分享MySQL数据库优化大全: MySQL数据库优化 云吞铺子先模拟一下数据库访问 ...
最新文章
- [转]C#网络编程(异步传输字符串) - Part.3
- 关于Java 垃圾收集器你应该知道这些
- 干货丨从概念到实践,我们该如何构建自动微分库
- 一个小网管的淘金梦----深圳往事(4)
- eclipseweb开发response和request接收发送数据乱码问题
- Linux学习之如何在物理机上安装Linux发行版
- 程序员最核心的竞争力是什么?
- iphone保修期多久_小心!iPhone翻新机,黑机,妖机,1978机千万别买!
- android 类型.this,Android中this的用法
- java程序a-z b-y_请完成下列Java程序:对大写的26个英文字母加密,从键盘输入一个大写字母串..._考试资料网...
- Redux 入门 -- 处理 async action
- 超详细 CSS动画-animation
- 如何做好学术演讲-01
- (已更新)网络祭祀人物小程序模板
- python对excel操作简书_python Excel 写
- 如何架设流媒体服务器
- ROSERROR : C++ filt命令
- 使用贝叶斯进行新闻分类
- 别翻了,Lambda 表达式入门,看这篇就够了
- Nodejs实现给手机发送短信验证码用于登录功能(免费短信)
热门文章
- Vue调试工具的安装方法(动动鼠标就完成,不会意外报错,超爽~)
- element ui 表格滚动条抖动的问题
- JavaScript-预解析(变量提升)
- 保存自动修复_CAD小技巧:怎样将自动保存的图形复原
- Darwin Streaming Server 安装流程
- 一个简单的基于 DirectShow 的播放器 1(封装类)
- c mysql dll_PHP5.3以上版本没有libmysql.dll,以及由此带来的困扰
- weex android 滑动事件,【报Bug】weex编译模式下slider组件 @scroll 事件, 滑块左右滑动, @scroll 回调的值始终是负数, 判断不了左右动作...
- 【POJ2887】Big String(块状链表,模板)
- 【网络流24题】【LOJ6013】负载平衡(环形纸牌均分,最小费最大流)