diff --git "a/48 \345\272\204\347\217\212\347\217\212/20230308 \345\244\247\344\275\234\344\270\232.md" "b/48 \345\272\204\347\217\212\347\217\212/20230308 \345\244\247\344\275\234\344\270\232.md" new file mode 100644 index 0000000000000000000000000000000000000000..9bb4ad87208ce97820c8e7a1885f4ceeb081bd38 --- /dev/null +++ "b/48 \345\272\204\347\217\212\347\217\212/20230308 \345\244\247\344\275\234\344\270\232.md" @@ -0,0 +1,184 @@ +# 1.大作业 + +```sql +# MySQL基础结课考试 + +## 考试时间 120 分钟 总分:100分 + +**场景**: + +你在一个软件公司上班,今天公司接一个新业务。要用MySQL给一个小说网站设计一个数据库。 + +**数据库名**:xiaoshuo +create database xiaoshuo charset utf8; +该数据库里有四张表:作家信息表 ( author )、作家等级信息表 ( vip )、小说作品信息表 ( story )、小说作品类型表 ( type ) +use xiaoshuo; +### 1、相关表结构 +1. 作家信息表 ( author ) (4分) +| 字段名称 | 数据类型 | 说明及要求 | +| ----------- | ----------- | --------------------------------- | +| author_id | int | 作家编号,主键 | +| author_name | varchar(20) | 作家姓名、非空、不能重复 | +| credits | int | 积分 | +| vip_id | varchar(20) | 等级编号,非空、外键关联等级信息表 | +create table author( + author_id int comment'作家编号' primary key , + author_name varchar(20) comment '作家姓名' not null unique , + credits int comment '积分', + vip_id varchar(20) comment '等级编号' not null +); +alter table author add constraint fk_vip_id 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) comment '等级编号'primary key , + vip_name varchar(20) comment '等级名称' not null unique +); +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 comment '作品编号' primary key auto_increment, + author_id int comment '作家编号', + type_id varchar(20) comment '类型编号', + story_name varchar(50) comment '作品名称 ', + views_number int comment '浏览量' +); +alter table story add constraint fk_author_id foreign key (author_id) references author(author_id); +alter table story add constraint fk_type_id foreign key (type_id) references type(type_id); +4. 小说作品类型表 ( type )(2分) +| 字段名称 | 数据类型 | 说明及要求 | +| --------- | ----------- | ------------------------ | +| type_id | varchar(20) | 类型编号,主键 | +| type_name | varchar(20) | 类型名称,非空,不能重复 | +create table type( + type_id varchar(20) comment '类型编号' primary key , + type_name varchar(20) comment '类型名称' not null unique +); +### 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 =1005 or author_id =1007; +5. 作家杜子腾,写了一篇名为《拜登夸我很帅》的都市小说,有854个浏览量,请将这条信息插入到story表。(3分) + insert into story values ('11','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,views_number from story where views_number >8000; +9. 查询积分大于1000 并且会员等级高于vip03的作家所有信息。(3分) + select * from author where vip_id>'vip03' and credits >1000; +10. 查询姓名以杜字开头的作家的姓名,积分和等级编号。(3分) + select author.author_name, author.credits, author.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_name) 作家数量 from author + group by vip_id; +14. 查询小说数量大于等于2的分类编号和小说数量。(4分) + select type_id 分类编号,count(story_name) 小说数量 from story group by type_id having count(story_name)>=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 作家的姓名,a.vip_id 等级名称 + from vip + right join author a on vip.vip_id = a.vip_id + left join story s on a.author_id = s.author_id + where vip_name ='白银作家' + and s.story_name is null; +18. 找出写过作品浏览量大于5000的作家的所有作品中浏览量不到1000的作品信息(8分) + select story_id, author_id, type_id, story_name, views_number from story where views_number<1000 + and author_id in (select a.author_id from story right join author a + on story.author_id = a.author_id where views_number>5000); +19. 查询所有小说的小说编号、小说名称、浏览量、分类名称、作者姓名、作者积分、作者等级名称,结果字段要用中文别名, + 并按浏览量降序排列,如果浏览量一样的,再按积分降序排列。(10分) + select story_id 小说编号, a.author_id 小说名称,views_number 浏览量,type_id 分类名称, author_name 作者姓名, + a.credits 作者积分,a.vip_id 作者等级名称 from story + inner join author a on story.author_id = a.author_id order by views_number desc,credits desc; +``` + +# 2.笔记 + +```sql +order by 后面多字段 +where 字段+条件 and 字段 in 子查询(select。。。) +更改:update 表 set 字段 =条件 +建库要 charset utf8; +``` +