From 4046612af928e6624f2325e5b6220e91adbfc01f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=91=A3=E5=BA=86=E5=BC=BA?= Date: Mon, 13 Mar 2023 04:27:13 +0000 Subject: [PATCH] =?UTF-8?q?=E5=A4=A7=E4=BD=9C=E4=B8=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: 董庆强 --- ...08\345\244\247\344\275\234\344\270\232.md" | 174 ++++++++++++++++++ 1 file changed, 174 insertions(+) create mode 100644 "17 \350\221\243\345\272\206\345\274\272/20230308\345\244\247\344\275\234\344\270\232.md" diff --git "a/17 \350\221\243\345\272\206\345\274\272/20230308\345\244\247\344\275\234\344\270\232.md" "b/17 \350\221\243\345\272\206\345\274\272/20230308\345\244\247\344\275\234\344\270\232.md" new file mode 100644 index 0000000..644039e --- /dev/null +++ "b/17 \350\221\243\345\272\206\345\274\272/20230308\345\244\247\344\275\234\344\270\232.md" @@ -0,0 +1,174 @@ +### 笔记 + +```sql +order by 默认是降序 升序是 desc +update 表 set 字段=字段+值 where 条件;#更新值 +``` + +### 作业 + +```sql +create database xiaoshuo charset utf8;- +use xiaoshuo; +#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, + creedits int, + vip_id varchar(20) not null +); +#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 +);#constraint +#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 +); +alter table story add foreign key(type_id) references type(type_id) on delete cascade on update cascade; +alter table story add foreign key(author_id) references author(author_id) on delete cascade on update cascade; +alter table author add foreign key(vip_id) references vip(vip_id) on delete cascade on update cascade; + +# 2、对应的表数据 + +#1. 作家信息表 (4分) +#| 作家编号 | 作家名称 | 积分 | 等级编号 | +#| :------: | :------: | :--: | :------: | +#| 1001 | 朱逸群 | 600 | VIP01 | +#| 1002 | 范建 | 8510 | VIP04 | + +# 1003 | 范统 | 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、题目 +#1. 根据前面提供的表结构和表数据,创建数据库并分别创建这张四张表;并插入相关数据。(提醒:外键请注意建表顺序和插入数据的顺序) (30分) +#2. 将story 表中的story_name字段类型改成varchar(40) 。(2分) +alter table story modify column story_name varchar(40); +#3. 在author表中增加一个性别字段 字段名:author_sex,类型: char(10),要求默认值为'男'。 (3分) +alter table author add column 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(11,1005,'L05','拜登夸我我很帅',854); +#6. 《拖拉机大战蜘蛛侠》这篇小说,浏览量涨了100,请更新story表中的相关数据。(2分) +update story set view_number=view_number+100 where story_name='拖拉机大战蜘蛛侠'; +#7. 请删除story表的中《皇上滚开本宫只劫财》这篇小说相关数据。(2分) +delete from story where story_name='皇上滚开本官只劫财'; +#8. 查询 浏览量大于 8000的小说的作者编号和小说作品名称。(2分) +select story_name from story where view_number>8000; +#9. 查询积分大于1000 并且会员等级高于vip03的作家所有信息。(3分) +select *from author left join vip on author.vip_id=vip.vip_id where creedits>1000 and author.vip_id>'VIP03'; +#10. 查询姓名以杜字开头的作家的姓名,积分和等级编号。(3分) +select *from author left join vip on author.vip_id=vip.vip_id where author_name like "杜%"; +#11. 查询积分在100、1000之间的作家信息,以积分降序排列。 (3分) +select*from author where creedits>100 and creedits<1000 order by creedits desc; +#12. 查询出小说的总浏览量,最高浏览量,最小浏览量,平均浏览量,给字段用上中文别名。(3分) +select sum(view_number) as 总浏览量,max(view_number) as 最高浏览量, min(view_number) as 最低浏览量, avg(view_number) as 平均浏览量 from story; +#13. 查询各种等级的作家的平均积分和作家数量,并对查询结果使用中文别名。(3分) +select vip_id,count(vip_id) as 作家数量,avg(creedits) from author right join story on author.author_id=story.author_id GROUP BY vip_id; +#14. 查询小说数量大于等于2的分类编号和小说数量.(4分) +select type_id,count(type_id) as 小说数量 from story group by type_id having count(type_id)>=2 ; +#15. 查询所有小说中浏览量最少的书的作品编号、作品名称和类型编号、浏览量.(4分) +select *from story where view_number=(select min(view_number) from story) ; +#16. 查询积分比刘产高的作者所有信息。(5分) +select*from author where creedits>(select creedits from author where author_name='刘产'); +#17. 查询出哪些白银作家是没有写小说的,显示这些作家的姓名、等级名称。(8分) +#18. 找出写过作品浏览量大于5000的作家的所有作品中浏览量不到1000的作品信息(8分) +select*from story where view_number>5000; +select*from story where view_number<1000; +select * from (select*from story where view_number>5000) as a inner join (select*from story where view_number<1000) as b on a.type_id=b.type_id; +#19.查询所有小说的小说编号、小说名称、浏览量、分类名称、作者姓名、作者积分、作者等级名称,结果字段要用中文别名,并按浏览量降序排列,如果浏览量一样的再按积分降序排列。(10分) +select * from author right join story on author.author_id=story.author_id left join type on type.type_id = story.type_id left join vip on vip.vip_id =author.vip_id order by view_number desc; +``` +``` -- Gitee