Day07-作业(MySQL查询设计)

chatgpt/2023/9/24 1:32:21

作业1: 根据如下需求完成SQL语句的编写 【仔细阅读题目需求呦】

数据准备:

  • 创建一个数据库 db02_homework

  • 执行如下SQL语句,准备测试数据

-- 员工管理(带约束)
create table tb_emp (id int unsigned primary key auto_increment comment 'ID',username varchar(20) not null unique comment '用户名',password varchar(32) default '123456' comment '密码',name varchar(10) not null comment '姓名',gender tinyint unsigned not null comment '性别, 说明: 1 男, 2 女',image varchar(300) comment '图像',job tinyint unsigned comment '职位, 说明: 1 班主任,2 讲师, 3 学工主管, 4 教研主管',entrydate date comment '入职时间',create_time datetime not null comment '创建时间',update_time datetime not null comment '修改时间'
) comment '员工表';-- 准备测试数据
INSERT INTO tb_emp (id, username, password, name, gender, image, job, entrydate, create_time, update_time) VALUES(1, 'jinyong', '123456', '金庸', 1, '1.jpg', 4, '2000-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:35'),(2, 'zhangwuji', '123456', '张无忌', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:37'),(3, 'yangxiao', '123456', '杨逍', 1, '3.jpg', 2, '2008-05-01', '2022-10-27 16:35:33', '2022-10-27 16:35:39'),(4, 'weiyixiao', '123456', '韦一笑', 1, '4.jpg', 2, '2007-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:41'),(5, 'changyuchun', '123456', '常遇春', 1, '5.jpg', 2, '2012-12-05', '2022-10-27 16:35:33', '2022-10-27 16:35:43'),(6, 'xiaozhao', '123456', '小昭', 2, '6.jpg', 3, '2013-09-05', '2022-10-27 16:35:33', '2022-10-27 16:35:45'),(7, 'jixiaofu', '123456', '纪晓芙', 2, '7.jpg', 1, '2005-08-01', '2022-10-27 16:35:33', '2022-10-27 16:35:47'),(8, 'zhouzhiruo', '123456', '周芷若', 2, '8.jpg', 1, '2014-11-09', '2022-10-27 16:35:33', '2022-10-27 16:35:49'),(9, 'dingminjun', '123456', '丁敏君', 2, '9.jpg', 1, '2011-03-11', '2022-10-27 16:35:33', '2022-10-27 16:35:51'),(10, 'zhaomin', '123456', '赵敏', 2, '10.jpg', 1, '2013-09-05', '2022-10-27 16:35:33', '2022-10-27 16:35:53'),(11, 'luzhangke', '123456', '鹿杖客', 1, '11.jpg', 2, '2007-02-01', '2022-10-27 16:35:33', '2022-10-27 16:35:55'),(12, 'hebiweng', '123456', '鹤笔翁', 1, '12.jpg', 2, '2008-08-18', '2022-10-27 16:35:33', '2022-10-27 16:35:57'),(13, 'fangdongbai', '123456', '方东白', 1, '13.jpg', 1, '2012-11-01', '2022-10-27 16:35:33', '2022-10-27 16:35:59'),(14, 'zhangsanfeng', '123456', '张三丰', 1, '14.jpg', 2, '2002-08-01', '2022-10-27 16:35:33', '2022-10-27 16:36:01'),(15, 'yulianzhou', '123456', '俞莲舟', 1, '15.jpg', 2, '2011-05-01', '2022-10-27 16:35:33', '2022-10-27 16:36:03'),(16, 'songyuanqiao', '123456', '宋远桥', 1, '16.jpg', 2, '2010-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:05'),(17, 'chenyouliang', '12345678', '陈友谅', 1, '17.jpg', null, '2015-03-21', '2022-10-27 16:35:33', '2022-10-27 16:36:07'),(18, 'zhang1', '123456', '张一', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:09'),(19, 'zhang2', '123456', '张二', 1, '2.jpg', 2, '2012-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:11'),(20, 'zhang3', '123456', '张三', 1, '2.jpg', 2, '2018-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:13'),(21, 'zhang4', '123456', '张四', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:15'),(22, 'zhang5', '123456', '张五', 1, '2.jpg', 2, '2016-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:17'),(23, 'zhang6', '123456', '张六', 1, '2.jpg', 2, '2012-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:19'),(24, 'zhang7', '123456', '张七', 1, '2.jpg', 2, '2006-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:21'),(25, 'zhang8', '123456', '张八', 1, '2.jpg', 2, '2002-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:23'),(26, 'zhang9', '123456', '张九', 1, '2.jpg', 2, '2011-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:25'),(27, 'zhang10', '123456', '张十', 1, '2.jpg', 2, '2004-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:27'),(28, 'zhang11', '123456', '张十一', 1, '2.jpg', 2, '2007-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:29'),(29, 'zhang12', '123456', '张十二', 1, '2.jpg', 2, '2020-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:31');

需求1:


-- 1. 查询指定字段 name,entrydate 并返回-- 2. 查询返回所有字段 (两种写法哦)-- 3. 查询所有员工的 name,entrydate, 并起别名 (姓名、入职日期)-- 4. 查询已有的员工关联了 哪几种 职位(不要重复)-- 5. 查询 姓名 为 '杨逍' 的员工-- 6. 查询在 id小于等于5 的员工信息-- 7. 查询 没有分配职位 的员工信息-- 8. 查询 有职位 的员工信息-- 9. 查询 密码不等于 '123456' 的员工信息-- 10. 查询入职日期 在 '2000-01-01' (包含) 到 '2010-01-01'(包含) 之间的员工信息-- 11. 查询 入职时间 在 '2000-01-01' (包含) 到 '2010-01-01'(包含) 之间 且 性别为女 的员工信息-- 12. 查询 职位是 2 (讲师) 或 3 (学工主管) 或 4 (教研主管) 的员工信息(两种写法实现)-- 13. 查询姓名为两个字的员工信息-- 14. 查询姓 '张' 的员工信息  且  入职时间在 '2008-01-01' 之后入职的员工-- 15. 查询出 性别为 男 , 或 入职时间在 2010-01-01 之后入职的员工-- 16. 根据性别分组 , 统计男性和女性员工的数量 (结果展示时, 性别不能展示 1 或 2 , 要转化为 男 或 女 )-- 17. 先查询入职时间在 '2015-01-01' (包含) 以前的员工 , 并对结果根据职位分组 , 获取员工数量大于等于2的职位-- 18. 查询所有的性别为男(gender 为 1)的 讲师 (job 为 2) , 并根据入职时间, 对员工进行升序排序-- 19. 根据 入职时间 对公司的员工进行 升序排序 , 入职时间相同 , 再按照 ID 进行降序排序-- 10. 查询性别为男(gender 为 1)的员工, 并根据 入职时间 对公司的员工进行 升序排序 , 入职时间相同 , 再按照 ID 进行降序排序-- 21. 查询性别为男(gender 为 1)的员工 且 在 '2018-10-01' 之前入职的员工, 并根据 入职时间 对公司的员工进行 升序排序 , 入职时间相同 , 再按照 ID 进行降序排序-- 22. 查询姓 '张' 且 在 '2018-10-01' 之前入职的员工, 并根据入职时间进行升序排序, 并对结果分页操作, 展示第1页员工数据, 每页展示5条记录-- 23. 查询所有性别为 '男' 且 职位 为 '讲师' 的员工数据, 并根据入职时间进行升序排序, 入职时间相同 根据id倒序排序, 并对结果分页操作,  并进行分页操作, 展示第2页员工数据, 每页展示5条记录-- 24. 查询所有员工的 姓名、性别、职位。 并满足如下两点要求:  (提示: if , case)
-- 1). 要求查询出来的结果中,性别要展示出 男/女,不要展示1/2 
-- 2). 要求查询出来的结果中,职位要展示出 班主任/讲师/学工主管/教研主管,而不要展示 1/2/3/4


作业2:根据如下需求编写对应的SQL语句

数据准备:

-- 员工管理
create table employee (id int unsigned primary key auto_increment comment 'ID',username varchar(20) not null unique comment '用户名',password varchar(32) default '123456' comment '密码',name varchar(10) not null comment '姓名',gender tinyint unsigned not null comment '性别, 说明: 1 男, 2 女',image varchar(300) comment '图像',job tinyint unsigned comment '职位, 说明: 1 班主任,2 讲师, 3 学工主管, 4 教研主管, 5 咨询师',entrydate date comment '入职时间',salary int unsigned comment '月工资',create_time datetime not null comment '创建时间',update_time datetime not null comment '修改时间'
) comment '员工表';INSERT INTO employee(id, username, password, name, gender, image, job, entrydate,salary, create_time, update_time) VALUES(1,'jinyong','123456','金庸',1,'1.jpg',4,'2000-01-01',20000,now(),now()),(2,'zhangwuji','123456','张无忌',1,'2.jpg',2,'2015-01-01',18000,now(),now()),(3,'yangxiao','123456','杨逍',1,'3.jpg',2,'2008-05-01',16800,now(),now()),(4,'weiyixiao','123456','韦一笑',1,'4.jpg',2,'2007-01-01',12000,now(),now()),(5,'changyuchun','123456','常遇春',1,'5.jpg',2,'2012-12-05',9000,now(),now()),(6,'xiaozhao','123456','小昭',2,'6.jpg',3,'2013-09-05',6000,now(),now()),(7,'jixiaofu','123456','纪晓芙',2,'7.jpg',1,'2005-08-01',6500,now(),now()),(8,'zhouzhiruo','123456','周芷若',2,'8.jpg',1,'2014-11-09',7200,now(),now()),(9,'dingminjun','123456','丁敏君',2,'9.jpg',1,'2011-03-11',5300,now(),now()),(10,'zhaomin','123456','赵敏',2,'10.jpg',1,'2013-09-05',12000,now(),now()),(11,'luzhangke','123456','鹿杖客',1,'11.jpg',5,'2007-02-01',8900,now(),now()),(12,'hebiweng','123456','鹤笔翁',1,'12.jpg',5,'2008-08-18',7800,now(),now()),(13,'fangdongbai','123456','方东白',1,'13.jpg',5,'2012-11-01',6800,now(),now()),(14,'zhangsanfeng','123456','张三丰',1,'14.jpg',2,'2002-08-01',15800,now(),now()),(15,'yulianzhou','123456','俞莲舟',1,'15.jpg',2,'2011-05-01',11500,now(),now()),(16,'songyuanqiao','123456','宋远桥',1,'16.jpg',2,'2007-01-01',8300,now(),now()),(17,'chenyouliang','123456','陈友谅',1,'17.jpg',NULL,'2015-03-21',4500,now(),now());

需求:

-- 1. 将 入职日期 在 '2000-01-01' (包含) 到 '2010-01-01'(包含) 之间的员工,工资统一涨 1000 
-- 提示: 如果更新某一个字段, 将其在原有基础上增加多少 , 可以使用 : .... set a = a + 10 这样的操作.-- 2. 将 工资在 5000 至 7000 或 性别为女 的员工,工资统一涨 500 , 提示: set salary = salary+500-- 3. 将 职位是 2 (讲师) 或 3 (学工主管) 或 4 (教研主管) 的员工的入职时间, 统一设置为 '2010-09-01'-- 4. 给没有分配职位的员工, 分配职位为 班主任-- 5. 删除 性别 为 女 , 且 岗位 为 咨询师 的员工信息


作业3:表结构设计

需求: 根据 资料/页面原型/tlias智能学习辅助系统 , 详细阅读页面原型及需求,完成 部门管理、员工管理、班级管理、学员管理 的表结构设计 。(主要考虑 多表关系 ,单表的表结构之前已经设计过了

提示: 涉及到的表有四张 , 部门表 tb_dept 、员工表 tb_emp 、班级表 tb_class 、学生表 tb_student。

基本表结构:

在下面的基础表结构中,并未考虑表与表之间的关系,比如:

  • 员工表 tb_emp 中没有当前员工归属的部门字段,需要大家自己添加。(并在comment备注中标注请求, 关联的是哪张表的哪个字段)

  • 班级表 tb_class 中没有当前班级的班主任信息(提示,班主任其实就是公司的员工),需要大家自己添加。(并在comment备注中标注请求, 关联的是哪张表的哪个字段)

  • 学员表 tb_student 中没有当前学员归属的班级,需要大家自己添加。(并在comment备注中标注请求, 关联的是哪张表的哪个字段)

-- 部门管理
create table tb_dept(id int unsigned primary key auto_increment comment '主键ID',name varchar(10) not null unique comment '部门名称',create_time datetime not null comment '创建时间',update_time datetime not null comment '修改时间'
) comment '部门表';-- 员工管理
create table tb_emp (id int unsigned primary key auto_increment comment 'ID',username varchar(20) not null unique comment '用户名',password varchar(32) default '123456' comment '密码',name varchar(10) not null comment '姓名',gender tinyint unsigned not null comment '性别, 说明: 1 男, 2 女',image varchar(300) comment '图像',job tinyint unsigned comment '职位, 说明: 1 班主任,2 讲师, 3 学工主管, 4 教研主管',entrydate date comment '入职时间',create_time datetime not null comment '创建时间',update_time datetime not null comment '修改时间'
) comment '员工表';-- 班级表
create table tb_class(id int unsigned primary key auto_increment comment 'ID,主键',name varchar(30) not null unique comment '班级名称',room varchar(20) comment '班级教室',begin date not null comment '开课时间',end date not null comment '结课时间',create_time datetime not null comment '创建时间',update_time datetime not null comment '修改时间'
) comment '班级表';-- 学员表
create table tb_student(id int unsigned primary key auto_increment comment 'ID,主键',name varchar(10) not null comment '姓名',no char(10) not null unique comment '学号',gender tinyint unsigned not null comment '性别, 1: 男, 2: 女',phone varchar(11) not null unique comment '手机号',degree tinyint unsigned comment '最高学历, 1:初中, 2:高中, 3:大专, 4:本科, 5:硕士, 6:博士',violation_count tinyint unsigned not null default 0 comment '违纪次数',violation_score tinyint unsigned not null default 0 comment '违纪扣分',create_time datetime not null comment '创建时间',update_time datetime not null comment '修改时间'
)


作业4 :面试题1 (case)

数据准备:

create table score(id int primary key auto_increment ,name varchar(10),chinese int,english int,math int
);insert into score values(1,'Tom',89,78,92),(2,'Rose',98,88,65),(3,'Jerry',55,70,43);

需求: 编写SQL语句,查询每个学生的id, name, 以及学生的语文chinese , 英语 english , 数学 math 的成绩等级.

规则:

  • >= 85 , 优秀

  • >= 60 且 < 85 , 及格

  • < 60 , 不及格

最终效果:

 


作业5 :面试题2 (case)

数据准备:

-- 班级人数表
create table tb_people(id int unsigned primary key auto_increment comment 'ID',name varchar(10) not null comment '班级',gender tinyint unsigned comment '性别, 1: 男, 2: 女',pcount int unsigned comment '人数'
) comment '班级人数表';insert into tb_people (id, name, gender, pcount)values(null,'三年级一班',1,34),(null,'三年级一班',2,12),(null,'三年级二班',1,56),(null,'三年级二班',2,14),(null,'三年级三班',1,22),(null,'三年级三班',2,43),(null,'三年级四班',1,26),(null,'三年级四班',2,38),(null,'四年级一班',1,45),(null,'四年级一班',2,13),(null,'四年级二班',1,18),(null,'四年级二班',2,27),(null,'四年级三班',1,19),(null,'四年级三班',2,26);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.exyb.cn/news/show-5313809.html

如若内容造成侵权/违法违规/事实不符,请联系郑州代理记账网进行投诉反馈,一经查实,立即删除!

相关文章

打卡力扣题目十一

#左耳听风 ARST 打卡活动重启# 目录 一、问题 二、解题方法一 三、解题方法二 四、区别 关于 ARTS 的释义 —— 每周完成一个 ARTS&#xff1a; ● Algorithm: 每周至少做一个 LeetCode 的算法题 ● Review: 阅读并点评至少一篇英文技术文章 ● Tips: 学习至少一个技术技巧 ●…

SciencePub学术 | 人工智能类重点SCIEEI征稿中

SciencePub学术 刊源推荐: 人工智能类重点SCIE&EI征稿中&#xff01;信息如下&#xff0c;录满为止&#xff1a; 一、期刊概况&#xff1a; 人工智能类重点SCIE&EI 【期刊简介】IF&#xff1a;6.5-7.0&#xff0c;JCR1区&#xff0c;中科院2区&#xff1b; 【出版社…

Nyan Progress Bar 更换进度条插件

打开idea 每天面对进度条怪无聊的&#xff0c;今天无意之中发现一个插件还挺有意思的 Nyan Progress Bar 当然啦&#xff0c;根据自己的喜欢进行选择 安装好之后&#xff0c;然后再打开idea

swagger前端传值

Parameter Type传值方法path直接在路径中传值bodydata传值queryparams传值 原生axios使用例子&#xff1a; this.$axios({url:/list/${id}, // path参数method:post,data: [123], // body参数params:{ type: 1 } // query参数 }).then(res> {console.log(res) })

DPN(Dual Path Network)网络结构详解

论文&#xff1a;Dual Path Networks 论文链接&#xff1a;https://arxiv.org/abs/1707.01629 代码&#xff1a;https://github.com/cypw/DPNs MXNet框架下可训练模型的DPN代码&#xff1a;https://github.com/miraclewkf/DPN 我们知道ResNet&#xff0c;ResNeXt&#xff0c;D…

数组的使用(逆序、冒泡)

内存连续数据类型相同从0开始索引 找出数组中的最大值 #include <iostream> #include <stdlib.h> //随机数所在文件 using namespace std;int main() {int arr[5]{104,134,145,129,89};//初始化没有填的为0 int max0;for(int i0;i<5;i){if(arr[i]>max){ma…

C++继承特性(1)——含义与继承方式的讲解

目录 1.继承的含义 2.继承的定义&#xff1a; 3.继承方式 例子1&#xff1a;基类的访问限定符为public&#xff0c;两个派生类的继承方式分别为public、protected时&#xff1a; 例子2&#xff1a; 基类的访问限定符为protected&#xff0c;两个派生类的继承方式分别为pub…

印度转向第一人口大国的背后,是红利还是负担?

KlipC报道&#xff1a;印度正在成为全球第一人口大国&#xff0c;人们对于该事件的关注也持续不断。 KlipC的合伙人Andi Duan表示&#xff1a;“自1881年以来&#xff0c;印度人口就一直增长&#xff0c;据联合国人口统计的数据显示”&#xff0c;今年4月印度人口已经成为全球最…
推荐文章