mysql单表查询与多表查询小练习
目录
一:
(1).创建emp表
(2).插入数据
编辑-- 1. 查询出部门编号为30的所有员工
编辑-- 2. 所有销售员的姓名、编号和部门编号。
-- 3. 找出奖金高于工资的员工。
-- 4. 找出奖金高于工资60%的员工。
编辑-- 5. 找出部门编号为10中所有经理,和部门编号为20中所有销售员的详细资料。
-- 6. 找出部门编号为10中所有经理,部门编号为20中所有销售员,还有即不是经理又不是销售员但其工资大或等于20000的所有员工详细资料。
-- 7. 无奖金或奖金低于1000的员工。
-- 8. 查询名字由三个字组成的员工。-- 注意:一个汉字占三个字节
-- 9.查询2000年入职的员工。
-- 10. 查询所有员工详细信息,用编号升序排序
-- 11. 查询所有员工详细信息,用工资降序排序,如果工资相同使用入职日期升序排序
-- 12.查询每个部门的平均工资
-- 13.查询每个部门的雇员数量
-- 14.查询每种工作的最高工资、最低工资、人数
二:
(1)创建部门表
(2) 给dept3表添加数据
(3)给emp3表添加数据
1、 查询每个部门的所属员工
编辑2、 查询研发部门的所属员工
3、 查询研发部和销售部的所属员工
4、 查询每个部门的员工数,并升序排序
编辑5、 查询人数大于等于3的部门,并按照人数降序排序
总结:
一:
(1).创建emp表
CREATE TABLE `emp` (
`empno` int(4) NOT NULL,
`ename` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
`job` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
`mgr` int(4) NULL DEFAULT NULL,
`hiredate` date NOT NULL,
`sai` int(255) NOT NULL,
`comm` int(255) NULL DEFAULT NULL,
`deptno` int(2) NOT NULL,
PRIMARY KEY (`empno`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
(2).插入数据
INSERT INTO `emp` VALUES (1001, '甘宁', '文员', 1013, '2000-12-17', 8000, NULL, 20);
INSERT INTO `emp` VALUES (1002, '黛绮丝', '销售员', 1006, '2001-02-20', 16000, 3000, 30);
INSERT INTO `emp` VALUES (1003, '殷天正', '销售员', 1006, '2001-02-22', 12500, 5000, 30);
INSERT INTO `emp` VALUES (1004, '刘备', '经理', 1009, '2001-04-02', 29750, NULL, 20);
INSERT INTO `emp` VALUES (1005, '谢逊', '销售员', 1006, '2001-09-28', 12500, 14000, 30);
INSERT INTO `emp` VALUES (1006, '关羽', '经理', 1009, '2001-05-01', 28500, NULL, 30);
INSERT INTO `emp` VALUES (1007, '张飞', '经理', 1009, '2001-09-01', 24500, NULL, 10);
INSERT INTO `emp` VALUES (1008, '诸葛亮', '分析师', 1004, '2007-04-19', 30000, NULL, 20);
INSERT INTO `emp` VALUES (1009, '曾阿牛', '董事长', NULL, '2001-11-17', 50000, NULL, 10);
INSERT INTO `emp` VALUES (1010, '韦一笑', '销售员', 1006, '2001-09-08', 15000, 0, 30);
INSERT INTO `emp` VALUES (1011, '周泰', '文员', 1006, '2007-05-23', 11000, NULL, 20);
INSERT INTO `emp` VALUES (1012, '程普', '文员', 1006, '2001-12-03', 9500, NULL, 30);
INSERT INTO `emp` VALUES (1013, '庞统', '分析师', 1004, '2001-12-03', 30000, NULL, 20);
INSERT INTO `emp` VALUES (1014, '黄盖', '文员', 1007, '2002-01-23', 13000, NULL, 10);
INSERT INTO `emp` VALUES (1015, '张三', '保洁员', 1001, '2013-05-01', 80000, 50000, 50);
表格如下:
-- 1. 查询出部门编号为30的所有员工
mysql> select * from emp-> where deptno = 30 ;
-- 2. 所有销售员的姓名、编号和部门编号。
mysql> select ename,empno,deptno from emp where job = '销售员';
-- 3. 找出奖金高于工资的员工。
mysql> select * from emp -> where comm > sai ;
-- 4. 找出奖金高于工资60%的员工。
mysql> select * from emp where comm > (sai*0.6);
-- 5. 找出部门编号为10中所有经理,和部门编号为20中所有销售员的详细资料。
mysql> select * from emp where (deptno=10 and job="经理") or (deptno=20 and job="销售员");
-- 6. 找出部门编号为10中所有经理,部门编号为20中所有销售员,还有即不是经理又不是销售员但其工资大或等于20000的所有员工详细资料。
mysql> select * from emp where (deptno=10 and job="经理") or (deptno=20 and job="销售员")-> or (job != "经理" and job != "销售员" and sai >= 20000);
-- 7. 无奖金或奖金低于1000的员工。
mysql> select * from emp where comm is NULL or comm < 1000;
-- 8. 查询名字由三个字组成的员工。
-- 注意:一个汉字占三个字节
mysql> select * from emp where length(ename) = 9;
-- 9.查询2000年入职的员工。
mysql> select * from emp where year(hiredate)=2000;
-- 10. 查询所有员工详细信息,用编号升序排序
mysql> select * from emp order by empno;
-- 11. 查询所有员工详细信息,用工资降序排序,如果工资相同使用入职日期升序排序
mysql> select * from emp order by sai desc,hiredate asc;
-- 12.查询每个部门的平均工资
mysql> select deptno,avg(sai) from emp group by deptno;
-- 13.查询每个部门的雇员数量
mysql> select deptno,count(*) from emp group by deptno;
这里忘了保存图片了;
-- 14.查询每种工作的最高工资、最低工资、人数
mysql> select job,max(sai),min(sai),count(*) from emp group by job;
二:
(1)创建部门表
create table if not exists dept3( deptno varchar(20) primary key , -- 部门号
name varchar(20) -- 部门名字 ); -- 创建员工表
create table if not exists emp3( eid varchar(20) primary key , -- 员工编号
ename varchar(20), -- 员工名字
age int, -- 员工年龄
dept_id varchar(20) -- 员工所属部门 );
(2) 给dept3表添加数据
insert into dept3 values('1001','研发部');
insert into dept3 values('1002','销售部');
insert into dept3 values('1003','财务部');
insert into dept3 values('1004','人事部');
(3)给emp3表添加数据
insert into emp3 values('1','乔峰',20, '1001');
insert into emp3 values('2','段誉',21, '1001');
insert into emp3 values('3','虚竹',23, '1001');
insert into emp3 values('4','阿紫',18, '1001');
insert into emp3 values('5','扫地僧',85, '1002');
insert into emp3 values('6','李秋水',33, '1002');
insert into emp3 values('7','鸠摩智',50, '1002');
insert into emp3 values('8','天山童姥',60, '1003');
insert into emp3 values('9','慕容博',58, '1003');
insert into emp3 values('10','丁春秋',71, '1005');
表格如下:
1、 查询每个部门的所属员工
mysql> select name,ename from dept3 d join emp3 e on e.dept_id=d.
deptno;
2、 查询研发部门的所属员工
mysql> select name,ename from dept3 d join emp3 e on e.dept_id=d.deptno where name = '研发部';
3、 查询研发部和销售部的所属员工
mysql> select * from dept3 d join emp3 e on e.dept_id=d.deptno where name = '研发部' or name = '销售部';
4、 查询每个部门的员工数,并升序排序
mysql> select name,count(1) sum from dept3 d join emp3 e on e.deptt_id=d.deptno -> group by name-> order by sum;
5、 查询人数大于等于3的部门,并按照人数降序排序
mysql> select name,count(1) sum from dept3 d join emp3 e on e.dept_id=d.deptno group by name having sum >= 3 order by sum desc;
总结:
当进行数据库查询时,我们通常使用单表查询和多表查询来获取所需的数据。单表查询是在单个表中检索数据,而多表查询涉及多个表之间的关联和连接。下面是对单表查询和多表查询的总结:
单表查询总结:
- 单表查询用于从单个表中检索数据。
- 使用SELECT语句指定要选择的列。
- 使用FROM子句指定要查询的表。
- 可以使用WHERE子句添加查询条件以限制结果集。
- 单表查询适用于在一个表中查找特定的数据,进行简单的数据检索和过滤。
多表查询总结:
- 多表查询用于在多个表之间关联和连接来检索数据。
- 使用SELECT语句指定要选择的列,并使用表的别名来区分列来自哪个表。
- 使用JOIN关键字指定连接方式(如INNER JOIN、LEFT JOIN等),并使用ON子句指定连接条件。
- 可以使用WHERE子句添加查询条件以限制结果集,并可以使用OR、AND等逻辑操作符进行条件的组合。
- 多表查询适用于需要在多个表中通过共同字段进行关联查询、获取多个表数据的联合结果以及根据不同的连接方式进行数据筛选。
在进行数据库查询时,除了掌握单表查询和多表查询的语法和技巧外,还应注意以下几点:
- 理解数据库表之间的关系和设计良好的表结构,以便正确选择连接方式,并能够编写有效的多表查询语句。
- 使用索引和适当的优化技术来提高查询性能,特别是在涉及大型数据集时。
- 使用别名来简化查询语句,提高可读性和可维护性。
- 验证查询结果的准确性,并根据需要进行必要的调整和优化。
通过掌握单表查询和多表查询,以及熟练运用相应的查询语句,我们可以更高效地从数据库中检索数据,并满足特定的业务需求。
mysql单表查询与多表查询小练习相关推荐
- mysql 单标递归_MYSQL递归树查询的实现
在oracle中我们可以使用connect by prior 函数来实现组织树表递归的查询,但是在mysql中却没有该方法,为了能够使用该方法我们就得自己创建函数来实现该组织树的递归查询.以 ...
- MySQL单表多字段模糊查询
今天工作时遇到一个功能问题:就是输入关键字搜索的字段不只一个字段,比如 我输入: 超天才 ,需要检索出 包含这个关键字的 name . company.job等多个字段.在网上查询了一会就找到了答案. ...
- MySQL之单表查询、多表查询(一)
阅读目录 一.单表查询: ①.基本语法执行顺序 ②.where约束条件的使用 ③.group by 分组 ④.having (类似于where,但是必须在group by语句后使用) ⑤.distin ...
- mysql为何500w拆表_【mysql】MySQL 单表500W+数据,查询超时,如何优化呢?
1.问题描述: MySQL 数据库,单表 `im_data_record`,查询超时(30s) 表结构如下图: 表索引如下图: 查询语句如下: SELECT `record_global_id`, ` ...
- MYSQL 单表一对多查询,将多条记录合并成一条记录
MYSQL 单表一对多查询,将多条记录合并成一条记录 一.描述: 在MySQL 5.6环境下,应工作需求:将一个表中多条某个相同字段的其他字段合并(不太会表达,有点绕,直接上图) 想要达到的效果: 实 ...
- mysql 单表多级查询_mysql单表与多表查询
单表查询 """ 增: insert [into] [数据库名.]表名[(字段1[, ..., 字段n])] values (数据1[, ..., 数据n])[, ... ...
- mysql单表查询详解
文章目录 一.单表查询 1.1 创建数据库 1.2 单表查询 1.2.1 查询所有字段 1.2.2 使用通配符*查询所有字段 1.2.3 查询指定字段 1.2.4 去重distinct的使用 1.2. ...
- mysql同张表关联多次查询_MySQL多次单表查询和多表联合查询
Tip:不建议执行三张表以上的多表联合查询 对数据量不大的应用来说,多表联合查询开发高效,但是多表联合查询在表数据量大,并且没有索引的时候,如果进行笛卡儿积,那数据量会非常大,sql执行效率会非常低 ...
- mysql单表查询实例_MySQL简单查询详解-单表查询
MySQL简单查询详解-单表查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查询的执行路径 一条SQL查询语句的执行过程大致如下图所示: 1>.客户端和服务端通过my ...
- Mysql单表查询和多表查询
单表查询 一 单表查询的语法 #查询数据的本质:mysql会到你本地的硬盘上找到对应的文件,然后打开文件,按照你的查询条件来找出你需要的数据.下面是完整的一个单表查询的语法select * from, ...
最新文章
- 亿条数据读取工具_仅需1秒!搞定100万行数据:超强Python数据分析利器
- 图形界面不卡的linux,图形化界面linux(linaro)的安装小结
- 如何运用python爬游戏皮肤_Python爬虫实战之 爬取王者荣耀皮肤
- zcmu1716(思维)
- Nginx 配置 SSL 证书步骤小记
- Sharepoint学习笔记---如何找到SharePoint List的Template ID
- Android获取当前位置,推荐使用百度地图SDK获取位置
- 51822模拟ble广播-理论
- VM虚拟机链接克隆及linux eth0网卡的快速设置方法
- HTML sublime :Please wait a bit while PyV8 binary is being downloaded 及代码和注释颜色 ,大小调节
- 虚拟机中 yum 安装时报错
- Machine Learning ——Homework 8
- 单片机C语言程序设计实训 100例—基于 8051+Proteus仿真
- 博弈论mooc期末考试答案
- linux伊甸园,新手学堂:给Ubuntu系统配置Java开发环境-Linux伊甸园----Linux|Unix|新闻|下载|论坛|人才|教程|自由软件|...
- 三级联动插件distpicker
- php curl 模拟微信公众号登入
- 面试中被问到:你在工作中碰到的最困难的问题是什么?
- status计算机语言,status 在c语言中的用法?请高手指教、、、、谢谢
- 5118站长工具箱:SEO数据分析浏览器插件 - 叶涛的博客
热门文章
- 达观OCR,图像文字抽取算法平台满足业务场景快速定制
- matlab pca svd,关于使用SVD进行PCA主成分提取的代码问题!也是必须涉及到原理的!...
- mysql paas化,一文彻底搞懂dbPaaS
- Go语言基础第07天(指针提高)
- 二分类最优阈值确定_AI初识:深度学习模型评估,从图像分类到生成模型
- windows卸载系统补丁
- python天气预报界面_Python开发,用GUI编写一个天气查询桌软件
- OutLook邮箱新收的邮件总是存储在C盘,如何修改默认存储位置?
- aws beanstalk mysql_教程和示例 - AWS Elastic Beanstalk
- nrf52382之定时器使用