diff --git "a/10 \346\234\261\345\277\227\351\271\217/\345\244\247\344\275\234\344\270\232.md" "b/10 \346\234\261\345\277\227\351\271\217/\345\244\247\344\275\234\344\270\232.md" new file mode 100644 index 0000000000000000000000000000000000000000..2a3c855531c0b9f638b65faa5b0d0871ceb8ccba --- /dev/null +++ "b/10 \346\234\261\345\277\227\351\271\217/\345\244\247\344\275\234\344\270\232.md" @@ -0,0 +1,103 @@ +```sql +create database xiaoshou charset utf8; +use xiaoshuo; +CREATE TABLE author ( + author_id INT PRIMARY KEY, + author_name VARCHAR(20) UNIQUE KEY not NULL, + credits INT, + vip_id VARCHAR(20) NOT NULL, + FOREIGN KEY (vip_id) REFERENCES vip(vip_id) +); +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'); +CREATE TABLE vip ( + vip_id VARCHAR(20) PRIMARY KEY, + vip_name VARCHAR(20) UNIQUE KEY not NULL +); +INSERT INTO vip VALUES +('VIP01','青铜作家'), +('VIP02','白银作家'), +('VIP03','黄金作家'), +('VIP04','钻石作家'); +CREATE TABLE story ( + story_id INT PRIMARY KEY auto_increment, + author_id INT, + type_id VARCHAR(20), + story_name VARCHAR(50), + views_number INT, + FOREIGN KEY (author_id) REFERENCES author(author_id), + FOREIGN KEY (type_id) REFERENCES type(type_id) +); +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); +CREATE TABLE type ( + type_id VARCHAR(20) PRIMARY KEY, + type_name VARCHAR(20) UNIQUE KEY not NULL +); +INSERT INTO type VALUES +('L01','玄幻'), +('L02','奇幻'), +('L03','武侠'), +('L04','仙侠'), +('L05','都市'); +select * from type; +-- 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 DROP author_sex; +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分) +DELETE FROM story WHERE views_number = 854 +INSERT INTO story(author_id,type_id,story_name,views_number) VALUES ((SELECT author_id FROM author WHERE author_name = '杜子腾'),'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.author_id,story_name FROM author RIGHT JOIN story ON author.author_id = story.author_id WHERE views_number>8000; +-- 9. 查询积分大于1000 并且会员等级高于vip03的作家所有信息。(3分) +SELECT * FROM author LEFT JOIN vip ON author.vip_id = vip.vip_id WHERE credits>1000 AND vip.vip_id NOT IN('VIP01','VIP02','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.vip_id 等级,AVG(credits) 平均积分,COUNT(*) 作家数量 FROM author +LEFT JOIN vip ON author.vip_id = vip.vip_id +GROUP BY author.vip_id; +-- 14. 查询小说数量大于等于2的分类编号和小说数量。(4分) +SELECT type_id,COUNT(*) FROM story GROUP BY type_id HAVING COUNT(type_id)>=2; +-- 15. 查询所有小说中浏览量最少的书的作品编号、作品名称和类型编号、浏览量。(4分) +SELECT story.author_id,story.story_name,story.type_id,story.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.author_name,author.vip_id FROM author LEFT JOIN story ON author.author_id = story.author_id +WHERE author.vip_id=(SELECT vip_id FROM vip WHERE vip_name = '白银作家')AND author.author_id 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 浏览量,a.author_name 分类名称,a.credits 作者积分,v.vip_name 作者等级名称 FROM author a +LEFT JOIN story s ON a.author_id = s.author_id +LEFT JOIN vip v ON a.vip_id = v.vip_id +ORDER BY views_number DESC,credits DESC; +```