From 3610583d3343f2e0f3db280734c0eda835a10667 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=AE=98=E6=96=87=E8=AF=9A?= <3287861587@qq.com> Date: Fri, 10 Mar 2023 12:08:11 +0800 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 --- ...09\345\244\247\344\275\234\344\270\232.md" | 187 ++++++++++++++++++ 1 file changed, 187 insertions(+) create mode 100644 "08 \345\256\230\346\226\207\350\257\232/20230309\345\244\247\344\275\234\344\270\232.md" diff --git "a/08 \345\256\230\346\226\207\350\257\232/20230309\345\244\247\344\275\234\344\270\232.md" "b/08 \345\256\230\346\226\207\350\257\232/20230309\345\244\247\344\275\234\344\270\232.md" new file mode 100644 index 0000000..315dffa --- /dev/null +++ "b/08 \345\256\230\346\226\207\350\257\232/20230309\345\244\247\344\275\234\344\270\232.md" @@ -0,0 +1,187 @@ +你在一个软件公司上班,今天公司接一个新业务。要用MySQL给一个小说网站设计一个数据库。 +数据库名:xiaoshuo + +~~~ sql +CREATE database xiaoshuo charset utf8; +use xiaoshuo; +~~~ + + 作家信息表 ( author ) + +~~~ sql +CREATE TABLE `author` ( + `author_id` int(11) NOT NULL, + `author_name` varchar(20) NOT NULL, + `credits` int(11) DEFAULT NULL, + `vip_id` varchar(20) NOT NULL, + PRIMARY KEY (`author_id`), + KEY `vip_id` (`vip_id`), + CONSTRAINT `author_ibfk_1` FOREIGN KEY (`vip_id`) REFERENCES `vip` (`vip_id`) +) ENGINE=InnoDB DEFAULT CHARSET=utf8; + + + +~~~ + + 作家等级信息表 ( vip ) + +~~~ sql +CREATE TABLE `vip` ( + `vip_id` varchar(20) NOT NULL, + `vip_name` varchar(20) NOT NULL, + PRIMARY KEY (`vip_id`) +) ENGINE=InnoDB DEFAULT CHARSET=utf8; +~~~ + +. 小说作品信息表 ( story ) + +~~~ sql +CREATE TABLE `story` ( + `story_id` int(11) NOT NULL AUTO_INCREMENT, + `author_id` int(11) DEFAULT NULL, + `type_id` varchar(20) DEFAULT NULL, + `story_name` varchar(50) DEFAULT NULL, + `views_number` int(11) DEFAULT NULL, + PRIMARY KEY (`story_id`), + KEY `author_id` (`author_id`), + KEY `type_id` (`type_id`), + CONSTRAINT `story_ibfk_1` FOREIGN KEY (`author_id`) REFERENCES `author` (`author_id`), + CONSTRAINT `story_ibfk_2` FOREIGN KEY (`type_id`) REFERENCES `type` (`type_id`) +) ENGINE=InnoDB DEFAULT CHARSET=utf8; +~~~ + + 小说作品类型表 ( type ) + +~~~ sql +CREATE TABLE `type` ( + `type_id` varchar(20) NOT NULL, + `type_name` varchar(20) NOT NULL, + PRIMARY KEY (`type_id`) +) ENGINE=InnoDB DEFAULT CHARSET=utf8; +~~~ + +## 表格 + +~~~ sql + +CREATE TABLE author( +author_id INT, +author_name VARCHAR(20), +credits int, +vip_id VARCHAR(20) +); + +CREATE TABLE vip( +vip_id VARCHAR(20), +vip_name VARCHAR(20) +); + + +CREATE TABLE story( +story_id INT, +author_id int, +type_id VARCHAR(20), +story_name VARCHAR(50), +views_number int +); + +CREATE TABLE type( +type_id VARCHAR(20), +type_name VARCHAR(20) +); +~~~ + + 作家信息表 + +~~~ sql +INSERT into author VALUES +(1001,'朱逸群',600,'VIP02'), +(1002,'范建',8510,'VIP04'), +(1003,'史珍香',981,'VIP02'), +(1004,'范统',2364,'VIP02'), +(1005,'杜子腾',257,'VIP01'), +(1006,'刘产',678,'VIP02'), +(1007,'杜琦燕',438,'VIP03'); +~~~ + + 等级信息表 + +~~~ sql +INSERT into vip VALUES +('VIP01','青铜作家'), +('VIP02','白银作家'), +('VIP03','黄金作家'), +('VIP04','钻石作家'); +~~~ + +小说作品信息表 + +~~~ sql +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','镜面管理局',3257), +(9,1004,'L02','关于我成为灭魂师之后',1147), +(10,1004,'L05','公子别秀',2078); +~~~ + + 作品类型 + +~~~ sql +INSERT into type VALUES +('L01','玄幻'), +('L02','奇幻'), +('L03','武侠'), +('L04','仙侠'), +('L05','都市'); +~~~ + +~~~ sql +-- 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(author_id,type_id,story_name,views_number) VALUES (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 * 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 round(avg(credits),2),count(vip_id) from author GROUP BY vip_id; +-- 14. 查询小说数量大于等于2的分类编号和小说数量。(4分) +SELECT author_id,count(author_id) a from story GROUP BY author_id HAVING a>=2; +-- 15. 查询所有小说中浏览量最少的书的作品编号、作品名称和类型编号、浏览量。(4分) +SELECT story_id,story_name,type_id,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 vip v left join author a on v.vip_id=a.vip_id left join story s on a.author_id=s.author_id where story_id is null and vip_name='白银作家'; +-- 18. 找出写过作品浏览量大于5000的作家的所有作品中浏览量不到1000的作品信息(8分) +select * from story where author_id =any (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_id 分类名称, a.author_name 作者姓名, a.credits 作者积分, v.vip_name 作者等级 from story s left join type t on s.type_id=t.type_id left join author a on +s.author_id=a.author_id left join vip v on a.vip_id=v.vip_id order by views_number desc,credits desc +~~~ + + + -- Gitee