diff --git "a/04 \345\220\264\350\211\257\347\241\274/20230307 \345\255\220\346\237\245\350\257\242.md" "b/04 \345\220\264\350\211\257\347\241\274/20230307 \345\255\220\346\237\245\350\257\242.md" new file mode 100644 index 0000000000000000000000000000000000000000..906880449a1ec8f74b61fe170ac70ec6b5ffff93 --- /dev/null +++ "b/04 \345\220\264\350\211\257\347\241\274/20230307 \345\255\220\346\237\245\350\257\242.md" @@ -0,0 +1,110 @@ +# 笔记 + +```mysql +子查询 +select语句中嵌套select语句,被嵌套的select语句称为子查询。 + +子查询可以出现在 select后面,from 后面,where 后面。 + +7.1where子句中的子查询 +找出比最低工资高的员工姓名和工资? + +select ename,sal from emp where sal > (select min(sal) from emp); +7.2from子句中的子查询 +from后面的子查询,可以将子查询的查询结果当做一张临时表。(技巧) +找出每个岗位的平均工资的薪资等级。 + +select + t.*, s.grade + from + (select job,avg(sal) as avgsal from emp group by job) t + join + salgrade s + on + t.avgsal between s.losal and s.hisal; +``` + +# 作业 + +```mysql +在如图的数据表上完成以下题目 +CREATE DATABASE xzx CHARSET utf8; +use xzx; +CREATE TABLE stuinfo( +stuno VARCHAR(100) PRIMARY KEY, +stuname VARCHAR(100), +stusex enum('男','女'), +stuage int, +stuaddress VARCHAR(10), +stuseat INT +) +alter table stuexam add foreign key (stuno) references stuinfo(stuno); + +CREATE TABLE stuexam( +examno int PRIMARY KEY, +stuno VARCHAR(100), + writtenexam int, +labexam INT +) +alter table stumarks add foreign key (examno) references stuexam(examno) on update CASCADE on delete CASCADE; +CREATE TABLE stumarks( +examno int PRIMARY KEY, +stuid VARCHAR(100), +score int +) +alter table stuinfo add foreign key (stuno) references stumarks(stuid) on update CASCADE on delete CASCADE; + +INSERT into stuinfo VALUES ('s2501','张秋利','男',20,'美国硅谷',1),('s2502','李斯文','女',18,'湖北武汉',2),('s2503','马文才','男',18,'湖南长沙',3),('s2504','欧阳俊雄','女',21,'湖北武汉',4),('s2505','梅超风','男',20,'湖北武汉',5),('s2506','陈旋风','男',19,'美国硅谷',6); + +INSERT into stuexam VALUES (1,'s2501',50,70),(2,'s2502',60,65),(3,'s2503',86,70),(4,'s2503',40,80),(5,'s2505',70,85),(6,'s2506',85,90); + +INSERT into stumarks VALUES (1,'s2501',88),(2,'s2501',92),(3,'s2501',53),(4,'s2502',60),(5,'s2502',99),(6,'s2503',82); +1.查询出年龄比班上平均年龄大的学生的信息 + +SELECT * from stuinfo WHERE stuage > (SELECT avg(stuage) from stuinfo); + +2.查询出每个学生的学号,姓名,性别和选修课程的最高分(stuMarks) +SELECT a.stuNO, a.stuName,a.stuSex,max( b.score ) FROM stuinfo a LEFT JOIN stuMarks b ON a.stuNO = b.stuID +GROUP BY + +3.查询出每个学生的学号,姓名,性别和考试平均分(stuExam) +SELECT SF.stuno,SF.stuname,SF.stusex,avg(writtenExam + labExam ) from stuinfo sf right JOIN stuexam sx on sf.stuno=sx.stuno GROUP BY examno; + +4.查询性别是男并且年龄大于等于20的学生的信息(用两种方法实现:普通查询和子查询) + +SELECT * from stuinfo WHERE stusex='男'AND stuage>=20; +SELECT * from (SELECT * from stuinfo WHERE stusex='男'AND stuage>=20) as s; +5.查询出年龄比所有男生年龄都大的女生的信息 + + +SELECT * from stuinfo WHERE stusex='女'and stuage > (SELECT max(stuage) from stuinfo WHERE stusex='男'); +6.查询出所有选修课程都及格的学生的信息 (stuMarks) +SELECT * from stuinfo sf LEFT JOIN stumarks sm on sf.stuno=sm.stuid WHERE sm.score>=60; + +7.查询出参加考试的学生的信息(用表连接,in二种方法做)(stuMarks) + +SELECT * FROM stuinfo a INNER JOIN ( SELECT DISTINCT stuid FROM stuMarks ) b ON a.stuNO = b.stuid; + +SELECT * from stuinfo WHERE stuno in (SELECT stuid from stumarks); +8.查询出没有参加考试的学生的信息(用表连接,in二种方法做)(stuMarks) +SELECT * from stuinfo sf left join stumarks sm on sm.stuid =sf.stuno WHERE stuid is null; +SELECT * from stuinfo WHERE stuno not in (SELECT stuid from stumarks ); + +9.将有一门成绩成绩大于90分的学生的基本信息查询出来(stuMarks) +SELECT * from stuinfo sf left JOIN stuMarks sm on sm.stuid =sf.stuno WHERE score>90; + +10.查询出平均成绩在80分以上的学生的基本信息(stuMarks) + +SELECT * from stuinfo sf INNER JOIN stumarks sm on sm.stuid =sf.stuno WHERE score > (SELECT avg(score) from stumarks); +11.查询出某同学所有考试成绩比“张秋利”同学所有分数都高的学生基本信息(stuMarks) +SELECT * FROM STUINFO sf LEFT JOIN STUMARKS sm on sm.stuid =sf.stuno WHERE SELECT score from stumarks WHERE='张秋利' +12.查询出某同学所有考试成绩只需要比“张秋利”同学某个分数高的学生基本信息(stuMarks) +SELECT * from +13.查询班上比所有男生年龄都要大的女生的信息 +SELECT* FROM stuinfo WHERE stuSex = '女' AND stuAge > ALL ( SELECT stuAge FROM stuinfo WHERE stuSex = '男' ) + +SELECT * from stuinfo WHERE stusex='女'and stuage>(SELECT max(stuage) from stuinfo WHERE stusex='男'); +14.查询出只是比某个男生年龄大的女生的信息 +SELECT* FROM stuinfo WHERE stuSex = '女' AND stuAge > any ( SELECT stuAge FROM stuinfo WHERE stuSex = '男' ) ; +``` + diff --git "a/04 \345\220\264\350\211\257\347\241\274/20230308 \347\273\203\344\271\240\344\275\234\344\270\232.md" "b/04 \345\220\264\350\211\257\347\241\274/20230308 \347\273\203\344\271\240\344\275\234\344\270\232.md" new file mode 100644 index 0000000000000000000000000000000000000000..ff9fc5fd150131097deeb3a384e81803258c6ee9 --- /dev/null +++ "b/04 \345\220\264\350\211\257\347\241\274/20230308 \347\273\203\344\271\240\344\275\234\344\270\232.md" @@ -0,0 +1,218 @@ +# 作业 + +``` +CREATE DATABASE j CHARSET utf8; +use j; + +# MySQL基础结课考试 + +## 考试时间 120 分钟 总分:100分 + +**场景**: + +你在一个软件公司上班,今天公司接一个新业务。要用MySQL给一个小说网站设计一个数据库。 + +**数据库名**:xiaoshuo + +该数据库里有四张表:作家信息表 ( author )、作家等级信息表 ( vip )、小说作品信息表 ( story )、小说作品类型表 ( type ) + +### 1、相关表结构 + +1. 作家信息表 ( author ) (4分) + +| 字段名称 | 数据类型 | 说明及要求 | +| ----------- | ----------- | --------------------------------- | +| author_id | int | 作家编号,主键 | +| author_name | varchar(20) | 作家姓名、非空、不能重复 | +| credits | int | 积分 | +| vip_id | varchar(20) | 等级编号,非空、外键关联等级信息表 | + +CREATE TABLE author( +author_id int PRIMARY key , +author_name varchar(20) not null unique key , +credits int , +vip_id varchar(20) not null +); +alter table author add foreign key (vip_id) references vip(vip_id); + +2. 作家等级信息表 ( vip ) (3分) + +| 字段名称 | 数据类型 | 说明及要求 | +| -------- | ----------- | ------------------------ | +| vip_id | varchar(20) | 等级编号,主键 | +| vip_name | varchar(20) | 等级名称,非空,不能重复 | + +CREATE TABLE vip ( +vip_id varchar(20) PRIMARY key, +vip_name varchar(20) not null unique key +); + +3. 小说作品信息表 ( story )(4分) + +| 字段名称 | 数据类型 | 说明及要求 | +| ------------ | ----------- | ----------------------------- | +| story_id | int | 作品编号,主键,自增 | +| author_id | int | 作家编号,外键,关联作家信息表 | +| type_id | varchar(20) | 类型编号,外键,关键作品类型表 | +| story_name | varchar(50) | 作品名称 | +| views_number | int | 浏览量 | + +CREATE table story( +story_id int PRIMARY key auto_increment, +author_id int, +type_id varchar(20), +story_name varchar(50), +views_number int +); +alter table story add foreign key (author_id) references author(author_id) on UPDATE CASCADE on DELETE CASCADE; +alter table story add FOREIGN key (type_id) REFERENCES type(type_id) on UPDATE CASCADE on DELETE CASCADE; + +4. 小说作品类型表 ( type )(2分) + + +| 字段名称 | 数据类型 | 说明及要求 | +| --------- | ----------- | ------------------------ | +| type_id | varchar(20) | 类型编号,主键 | +| type_name | varchar(20) | 类型名称,非空,不能重复 | + +CREATE TABLE type ( +type_id varchar(20) PRIMARY key, +type_name varchar(20) not null unique KEY +); + + +### 2、对应的表数据 + +1. 作家信息表 (4分) + + +| 作家编号 | 作家名称 | 积分 | 等级编号 | +| :------: | :------: | :--: | :------: | +| 1001 | 朱逸群 | 600 | VIP01 | +| 1002 | 范建 | 8510 | VIP04 | +| 1003 | 史珍香 | 981 | VIP02 | +| 1004 | 范统 | 2364 | VIP02 | +| 1005 | 杜子腾 | 257 | VIP01 | +| 1006 | 刘产 | 678 | VIP02 | +| 1007 | 杜琦燕 | 438 | VIP03 | + +INSERT into author VALUES( 1001 ,'朱逸群',600,'VIP01'),( 1002, '范建', 8510,'VIP04'),( 1003,'史珍香' ,981,'VIP02'),( 1004,'范统' ,2364 ,'VIP02'),( 1005,'杜子腾',257, 'VIP01'),( 1006,'刘产', 678,'VIP02'),( 1007,'杜琦燕', 438 ,'VIP03'); + + + +2. 等级信息表(2分) + +| 等级编号 | 等级名称 | +| :----------------------------------------------------------: | :------: | +| VIP01 | 青铜作家 | +| VIP02 | 白银作家 | +| VIP03 | 黄金作家 | +| VIP04 | 钻石作家 | +| INSERT into vip VALUES('VIP01','青铜作家'),('VIP02','白银作家'),('VIP03','黄金作家'),('VIP04','钻石作家'); | | + + +3. 小说作品信息表(5分) + +| 作品编号 | 作家编号 | 类型编号 | 作品名称 | 订阅数 | +| :------: | :------: | :------: | :----------------------: | :----: | +| 1 | 1002 | L03 | 母猪产后与护理师的二三事 | 6541 | +| 2 | 1005 | L04 | 拖拉机大战蜘蛛侠 | 563 | +| 3 | 1003 | L01 | 这只小龙虾不正经 | 8754 | +| 4 | 1006 | L04 | 一个爹爹三个娃 | 36354 | +| 5 | 1006 | L01 | 皇上滚开本宫只劫财 | 3674 | +| 6 | 1005 | L05 | 给长城贴瓷砖的小太监 | 6541 | +| 7 | 1003 | L03 | 不科学御兽 | 1257 | +| 8 | 1005 | L01 | 镜面管理局 | 3216 | +| 9 | 1004 | L02 | 关于我成为灭魂师之后 | 1147 | +| 10 | 1004 | L05 | 公子别 秀 | 2078 | + + + + +insert into story values +(1,1002,'L03','母猪产后与护理师的二三事',6541), +(2,1005,'L04','拖拉机大战蜘蛛侠',563), +(3,1003,'L01','这只小龙虾不正经',8754), +(4,1006,'L04','一个爹爹三个娃',36354), +(5,1006,'L01','皇上滚开本宫只劫财',3674), +(6,1005,'L05','给长城贴瓷砖的小太监',6541), +(7,1003,'L03','不科学御兽',1257), +(8,1005,'L01','镜面管理局',3216), +(9,1004,'L02','关于我成为灭魂师之后',1147), +(10,1004,'L05','公子别秀',2078); + +4. 作品类型(3分) + +| 类型编号 | 类型名称 | +| :------: | :------: | +| L01 | 玄幻 | +| L02 | 奇幻 | +| L03 | 武侠 | +| L04 | 仙侠 | +| L05 | 都市 | + +INSERT into type VALUES('L01','玄幻'),('L02','奇幻'),('L03','武侠'),('L04','仙侠'),('L05','都市'); + +-- ### 3、题目 +-- + +-- > 所有题目要求使用SQL语句完成 +-- + +-- 1. 根据前面提供的表结构和表数据,创建数据库并分别创建这张四张表;并插入相关数据。(提醒:外键请注意建表顺序和插入数据的顺序) (30分) +-- + +-- 2. 将story 表中的story_name字段类型改成varchar(40) 。(2分) + alter table story modify story_name varchar(40); +-- 3. 在author表中增加一个性别字段 字段名:author_sex,类型: char(10),要求默认值为'男'。 (3分) + alter table author add author_sex char(10) default '男'; +-- 4. 将作家编号为1005、1007的作家性别改为'女' 。(2分) + update author set author_sex='女' where author_id in (1005,1007); +-- 5. 作家杜子腾,写了一篇名为《拜登夸我很帅》的都市小说,有854个浏览量,请将这条信息插入到story表。(3分) + +​ insert into story values(null,1005,'L05','拜登夸我很帅',854); + +-- 6. 《拖拉机大战蜘蛛侠》这篇小说,浏览量涨了100,请更新story表中的相关数据。(2分) + +​ update story set views_number=views_number+100 where story_name='拖拉机大战蜘蛛侠'; + +-- 7. 请删除story表的中《皇上滚开本宫只劫财》这篇小说相关数据。(2分) + DELETE from story WHERE story_name='皇上滚开本宫只劫财'; +-- 8. 查询 浏览量大于 8000的小说的作者编号和小说作品名称。(2分) +SELECT author_id,story_name from story WHERE views_number>8000; +-- 9. 查询积分大于1000 并且会员等级高于vip03的作家所有信息。(3分) +SELECT * from author WHERE credits>1000 and vip_id > 'vip03'; +-- 10. 查询姓名以杜字开头的作家的姓名,积分和等级编号。(3分) +SELECT author_name,credits,vip_id from author WHERE author_name like '杜%'; + + +-- 11. 查询积分在100、1000之间的作家信息,以积分降序排列。 (3分) +SELECT * from author WHERE credits BETWEEN 100 and 1000 order by credits desc; +-- 12. 查询出小说的总浏览量,最高浏览量,最小浏览量,平均浏览量,给字段用上中文别名。(3分) +SELECT sum(views_number) 总浏览量,max(views_number)最高浏览量,MIN(views_number)最小浏览量, AVG(views_number)平均浏览量 from story; +-- 13. 查询各种等级的作家的平均积分和作家数量,并对查询结果使用中文别名。(3分) +SELECT vip_id,AVG(credits)平均积分,count(author_id)作家数量 from author GROUP BY vip_id; +-- 14. 查询小说数量大于等于2的分类编号和小说数量。(4分) +SELECT t.type_id,COUNT(t.type_id) from story s LEFT JOIN type t ON s.type_id=t.type_id GROUP BY type_name HAVING COUNT(t.type_id)>=2; +-- 15. 查询所有小说中浏览量最少的书的作品编号、作品名称和类型编号、浏览量。(4分) + +SELECT story_id, story_name,type_id, views_number from story WHERE views_number = (SELECT MIN(views_number) from story); + +-- 16. 查询积分比刘产高的作者所有信息。(5分) +SELECT * from author WHERE credits > (SELECT credits from author WHERE author_name='刘产'); +-- 17. 查询出哪些白银作家是没有写小说的,显示这些作家的姓名、等级名称。(8分) + +SELECT author_name,vip_name from author left join vip on author.vip_id=vip.vip_id left JOIN story on author.author_id=story.author_id WHERE vip_name ='白银作家' and story.story_name is null ; +-- 18. 找出写过作品浏览量大于5000的作家的所有作品中浏览量不到1000的作品信息(8分) +SELECT * from story WHERE author_id in + +(SELECT author_id from story WHERE views_number >5000 ) and views_number <1000; +-- 19. 查询所有小说的小说编号、小说名称、浏览量、分类名称、作者姓名、作者积分、作者等级名称,结果字段要用中文别名,并按浏览量降序排列,如果浏览量一样的,再按积分降序排列。(10分) +SELECT s.story_id'小说编号' ,s.story_name'小说名称',s.views_number'浏览量',t.type_name'分类名称',a.author_name'作者姓名', a.credits'作者积分',v.vip_name'作者等级名称' from story s LEFT JOIN author a on s.author_id=a.author_id +left join vip v on v.vip_id =a.vip_id +LEFT JOIN type t on s.type_id= t.type_id + ORDER BY s.views_number desc , a.credits desc; + + +``` +