diff --git "a/05 \350\226\233\347\245\226\344\277\241/2023228 \350\201\224\345\220\210\346\237\245\350\257\242\347\232\204\345\255\246\344\271\240.md" "b/05 \350\226\233\347\245\226\344\277\241/20230228 \350\201\224\345\220\210\346\237\245\350\257\242\347\232\204\345\255\246\344\271\240.md" similarity index 100% rename from "05 \350\226\233\347\245\226\344\277\241/2023228 \350\201\224\345\220\210\346\237\245\350\257\242\347\232\204\345\255\246\344\271\240.md" rename to "05 \350\226\233\347\245\226\344\277\241/20230228 \350\201\224\345\220\210\346\237\245\350\257\242\347\232\204\345\255\246\344\271\240.md" diff --git "a/05 \350\226\233\347\245\226\344\277\241/20230308 \347\273\203\344\271\240\344\270\216\344\275\234\344\270\232.md" "b/05 \350\226\233\347\245\226\344\277\241/20230308 \347\273\203\344\271\240\344\270\216\344\275\234\344\270\232.md" new file mode 100644 index 0000000000000000000000000000000000000000..50490dea5b16833d43e1d1017ff76d2488b4fe2d --- /dev/null +++ "b/05 \350\226\233\347\245\226\344\277\241/20230308 \347\273\203\344\271\240\344\270\216\344\275\234\344\270\232.md" @@ -0,0 +1,209 @@ +# 1. 作业 + +```sql +-- # MySQL基础结课考试 +-- +-- ## 考试时间 120 分钟 总分:100分 +-- +-- **场景**: +-- +-- 你在一个软件公司上班,今天公司接一个新业务。要用MySQL给一个小说网站设计一个数据库。 +-- +-- **数据库名**:xiaoshuo + create database xiaoshuo charset utf8; + use 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) on update cascade on delete cascade; +-- +-- 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), + view_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 | +desc author; +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 | 钻石作家 | +-- +desc vip; +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 | +-- +desc story; +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 | 都市 | +-- +desc type; +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 AUTHOR.* from story inner join author on author.author_id=story.author_id where views_number>1000 and vip_id > 'VIP03' ; +-- 10. 查询姓名以杜字开头的作家的姓名,积分和等级编号。(3分) + select author_name,views_number,author.vip_id from author inner join story on author.author_id=story.author_id 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 type.type_id,count(type.type_id) from story inner join type on story.type_id=type.type_id group by type.type_id having count(type.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分) + + +-- 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 story_id 小说编号,story_name 小说名称,views_number 浏览量,type.type_name 分类名称,author.author_name 作者姓名,author.credits 作者积分 ,vip.vip_name 作者等级名称 from story inner join + type on story.type_id=type.type_id inner join author on story.author_id=author.author_id inner join + vip on vip.vip_id=author.vip_id order by views_number desc; +``` + diff --git "a/05 \350\226\233\347\245\226\344\277\241/20230309 \344\275\234\344\270\232.md" "b/05 \350\226\233\347\245\226\344\277\241/20230309 \344\275\234\344\270\232.md" new file mode 100644 index 0000000000000000000000000000000000000000..1c0ec9ca77b74651ba9127dd896378b4b838d0fd --- /dev/null +++ "b/05 \350\226\233\347\245\226\344\277\241/20230309 \344\275\234\344\270\232.md" @@ -0,0 +1,107 @@ +# 1. 作业 + +```sql +-- 按图片所给的数据进行数据表的建立和数据插入,然后进行以下查询操作 +-- + create database xy charset utf8; + use xy; + create table stuinfo( + stuno varchar(10) primary key, + stuname varchar(10), + stuage int, + stuaddress varchar(10), + stuseat int, + stusex enum('0','1') + ); + insert into stuinfo values ('s2501','张秋利',20,'美国硅谷',1,'1'), + ('s2502','李斯文',18,'湖北武汉',2,'0'), + ('s2503','马文才',22,'湖南长沙',3,'1'), + ('s2504','欧阳俊雄',21,'湖北武汉',4,'0'), + ('s2505','梅超风',20,'湖北武汉',5,'1'), + ('s2506','陈旋风',19,'美国硅谷',6,'1'), + ('s2507','陈风',20,'美国硅谷',7,'0'); + + + + create table stuexam( + examno int primary key auto_increment, + stuno varchar(10), + writtenexam int, + labexam int + ); + + insert into stuexam values (1,'s2501',50,70), + (2,'s2502',60,65), + (3,'s2503',86,85), + (4,'s2504',40,80), + (5,'s2505',70,90), + (6,'s2506',85,90); + + alter table stuexam add foreign key (stuno) references stuinfo(stuno); + +-- 1.查询学生信息表(stuinfo)中所有列信息,给每列取上中文名称 +select * from stuinfo; + select stuno 学号,stuname 姓名, stuage 年龄, stuaddress 家庭地址, stuseat 座位号, + stusex 性别 from stuinfo; +-- 2.查询学生信息表(stuinfo)中的姓名,年龄和地址三列的信息 + select stuname,stuage,stuaddress from stuinfo; +-- 3.查询学生分数表(stuexam)中的学号,笔试和机试三列的信息,并为这三列取中文名字 + select stuno 学号,writtenexam 笔试,labexam 机试 from stuexam; +-- 5.查询学生分数表(stuexam)中的学生的学号,笔试,机试以及总分这四列的信息 + select stuno 学号,writtenexam 笔试,labexam 机试,(writtenexam+labexam) 总分 from stuexam; + +-- 6.查询学生信息表(stuInfo)中学生来自哪几个地方 + select stuaddress from stuinfo group by stuaddress; +-- 7.查询学生信息表(stuInfo)中学生有哪几种年龄,并为该列取对应的中文列名 + select stuage 年龄 from stuinfo group by stuage; +-- 8.查询学生信息表(stuInfo)中前3行记录 + select * from stuinfo limit 0,3; +-- 9.查询学生信息表(stuInfo)中前4个学生的姓名和座位号 + select stuname,stuseat from stuinfo limit 0,4; +-- 11.将地址是湖北武汉,年龄是20的学生的所有信息查询出来 + select * from stuinfo where stuaddress='湖北武汉' and stuage=20; +-- 12.将机试成绩在60-80之间的信息查询出来,并按照机试成绩降序排列 + select * from stuexam where labexam between 60 and 80 order by labexam desc; +-- 13.查询来自湖北武汉或者湖南长沙的学生的所有信息 + select * from stuinfo where stuaddress in('湖北武汉','湖南长沙'); +-- 14.查询出笔试成绩不在70-90之间的信息,并按照笔试成绩升序排列 + select * from stuexam where !(writtenexam between 70 and 90) order by writtenexam ; +-- 15.查询年龄没有写的学生所有信息 + select * from stuinfo where stuage is null; +-- 16.查询年龄写了的学生所有信息 + select * from stuinfo where stuage is not null; +-- 17.查询姓张的学生信息 + select * from stuinfo where stuname like '张%'; +-- 18.查询学生地址中有‘湖’字的信息 + select * from stuinfo where stuaddress like '%湖%'; +-- 19.查询姓张但名为一个字的学生信息 + select * from stuinfo where stuname like '张_'; +-- 20.查询姓名中第三个字为‘俊’的学生的信息,‘俊’后面有多少个字不限制 + select * from stuinfo where stuname like '__俊%'; +-- 21.按学生的年龄降序显示所有学生信息 + select * from stuinfo order by stuage desc; +-- 22.按学生的年龄降序和座位号升序来显示所有学生的信息 + select * from stuinfo order by stuage desc , stuseat asc; +-- 23显示笔试第一名的学生的考试号,学号,笔试成绩和机试成绩 + select examno,stuno,writtenexam,labexam from stuexam where writtenexam=(select max(writtenexam) from stuexam ); +-- 24.显示机试倒数第一名的学生的考试号,学号,笔试成绩和机试成绩 + select examno,stuno,writtenexam,labexam from stuexam where labexam=(select min(labexam) from stuexam ); + +-- 25.查询每个地方的学生的平均年龄 + select avg(stuage) from stuinfo GROUP BY stuaddress; +-- 26.查询男女生的分别的年龄总和 + select sum(stuage) from stuinfo GROUP BY stusex; +-- 27.查询每个地方的男女生的平均年龄和年龄的总和 + select stuaddress,stusex,avg(stuage),sum(stuage) from stuinfo group by stuaddress,stusex; +-- +-- +-- +-- +-- +-- +-- +-- +-- +-- +``` +