From ded44ecd14ed72790a55057ac06717d14be34ff2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=BE=90=E6=B0=B8=E6=B7=B3?= <2678158018@qq.com> Date: Fri, 10 Mar 2023 13:43:31 +0800 Subject: [PATCH] =?UTF-8?q?=E7=AC=AC=E4=BA=94=E6=AC=A1=E4=BD=9C=E4=B8=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...56\345\272\223\344\275\234\344\270\232.md" | 121 ++++++++++++++++++ 1 file changed, 121 insertions(+) create mode 100644 "18 \345\276\220\346\260\270\346\267\263/20230310 \346\225\260\346\215\256\345\272\223\344\275\234\344\270\232.md" diff --git "a/18 \345\276\220\346\260\270\346\267\263/20230310 \346\225\260\346\215\256\345\272\223\344\275\234\344\270\232.md" "b/18 \345\276\220\346\260\270\346\267\263/20230310 \346\225\260\346\215\256\345\272\223\344\275\234\344\270\232.md" new file mode 100644 index 0000000..ac1e0a1 --- /dev/null +++ "b/18 \345\276\220\346\260\270\346\267\263/20230310 \346\225\260\346\215\256\345\272\223\344\275\234\344\270\232.md" @@ -0,0 +1,121 @@ +````mysql +``` + +``` + + + +CREATE DATABASE xiaoshuo CHARSET utf8; +use xiaoshuo; +CREATE TABLE author( +author_id int PRIMARY KEY,-- 作家编号,主键 +author_name varchar(20) not null UNIQUE KEY,-- 作家姓名、非空、不能重复 +credits int,-- 积分 +vip_id varchar(20) not null, +FOREIGN KEY (vip_id) REFERENCES vip(vip_id)-- 等级编号,非空、外键关联等级信息表 +); +set FOREIGN_key_checks=0; +DROP TABLE author; +CREATE TABLE vip( +vip_id varchar(20) PRIMARY KEY,-- 等级编号,主键 +vip_name varchar(20) NOt null UNIQUE KEY -- 等级名称,非空,不能重复 +); +CREATE TABLE story ( +story_id int PRIMARY key auto_increment,-- 作品编号,主键,自增 +author_id int,-- 作家编号,外键,关联作家信息表 +FOREIGN KEY (author_id) REFERENCES author(author_id), +type_id varchar(20),-- 类型编号,外键,关键作品类型表 +FOREIGN KEY (type_id) references type(type_id), +story_name varchar(50),-- 作品名称 +views_number int -- 浏览量 +); +CREATE TABLE type( +type_id varchar(20) PRIMARY KEY,-- 类型编号,主键 +type_name varchar(20) not NULL UNIQUE KEY-- 类型名称,非空,不能重复 +); +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'); +INSERT INTO vip VALUES +('VIP01','青铜作家'), +('VIP02','白银作家'), +('VIP03','黄金作家'), +('VIP04','钻石作家'); +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); +INSERT INTO type vALUES +('L01','玄幻'), +('L02','奇幻'), +('L03','武侠'), +('L04','仙侠'), +('L05','都市'); + +-- 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分) +SELECT * FROM author; +UPDATE author SET author_sex='女' WHERE author_id=1005 || author_id=1007; +-- 5. 作家杜子腾,写了一篇名为《拜登夸我很帅》的都市小说,有854个浏览量,请将这条信息插入到story +-- 表。(3分) +SELECT * FROM story; +INSERT into story(story_name,views_number) VALUES('拜登夸我很帅',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 * 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 GROUP BY credits desc; +-- 12. 查询出小说的总浏览量,最高浏览量,最小浏览量,平均浏览量,给字段用上中文别名。(3分) +SELECT SUM(views_number) 总浏览量,max(views_number) 最高浏览量,min(views_number) 最小浏览量,AVG(views_number) 平均浏览量 FROM story; +-- 13. 查询各种等级的作家的平均积分和作家数量,并对查询结果使用中文别名。(3分) +SELECT avg(credits),COUNT(author_id) FROM author GROUP BY author_id; +-- 14. 查询小说数量大于等于2的分类编号和小说数量。(4分) +SELECT type.type_id,COUNT(type.type_id) from story LEFT JOIN type ON story.type_id=type.type_id GROUP BY type_name HAVING COUNT(type.type_id)>=2; +-- 15. 查询所有小说中浏览量最少的书的作品编号、作品名称和类型编号、浏览量。(4分) +SELECT * FROM story; +SELECT *,MIN(views_number) FROM story; + +-- 16. 查询积分比刘产高的作者所有信息。(5分) +SELECT * from author; +(SELECT credits FROM author WHERE author_name='刘产'); +SELECT * FROM author WHERE credits >(SELECT credits FROM author WHERE author_name='刘产'); +-- 17. 查询出哪些白银作家是没有写小说的,显示这些作家的姓名、等级名称。(8分) +SELECT story_id, story_name,type_id,views_number FROM story WHERE views_number = (SELECT MIN(views_number) FROM story); + +-- 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'浏览量',t.type_name'分类名称',a.author_name'作者姓名', a.credits'作者积分',v.vip_name'作者等级名称' from story s LEFT JOIN author a on s.author_id=a.author_id +left join vip v on v.vip_id =a.vip_id +LEFT JOIN type t on s.type_id= t.type_id + ORDER BY s.views_number desc , a.credits desc; +```` + + + -- Gitee