From b55a2205d36d2261a15ecc52e4122b20559cf129 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=83=A1=E6=99=BA=E7=A0=94?= <3058944672@qq.com> Date: Sun, 12 Mar 2023 18:56:43 +0800 Subject: [PATCH] =?UTF-8?q?=E7=AC=AC=E4=B8=83=E6=AC=A1=E4=BD=9C=E4=B8=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...46\254\241\344\275\234\344\270\232,md.txt" | 92 +++++++++++++++++++ 1 file changed, 92 insertions(+) create mode 100644 "46 \350\203\241\346\231\272\347\240\224/20230312\347\254\254\344\270\203\346\254\241\344\275\234\344\270\232,md.txt" diff --git "a/46 \350\203\241\346\231\272\347\240\224/20230312\347\254\254\344\270\203\346\254\241\344\275\234\344\270\232,md.txt" "b/46 \350\203\241\346\231\272\347\240\224/20230312\347\254\254\344\270\203\346\254\241\344\275\234\344\270\232,md.txt" new file mode 100644 index 0000000..ff97de2 --- /dev/null +++ "b/46 \350\203\241\346\231\272\347\240\224/20230312\347\254\254\344\270\203\346\254\241\344\275\234\344\270\232,md.txt" @@ -0,0 +1,92 @@ +CREATE DATABASE xiaoshuo charset utf8; +use xiaoshuo; +CREATE TABLE author( +author_id int PRIMARY KEY, +author_name varchar(20) NOT NULL unique, +credits int, +vip_id varchar(20) NOT NULL, +FOREIGN KEY (vip_id) REFERENCES vip(vip_id) +); +CREATE TABLE vip( +vip_id varchar(20) PRIMARY KEY, +vip_name varchar(20) unique NOT NULL +); +CREATE TABLE type( +type_id varchar(20) PRIMARY KEY, +type_name varchar(20) NOT NULL unique +); +CREATE TABLE story( +story_id int PRIMARY KEY auto_increment, +author_id int, +type_id varchar(20), +story_name varchar(20), +views_number int, +FOREIGN KEY (author_id) REFERENCES author(author_id), +FOREIGN key (type_id) REFERENCES type(type_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'); +INSERT INTO vip VALUES ('VIP01',' 青铜作家'), + ('VIP02',' 白银作家'), + ('VIP03',' 黄金作家'), + ('VIP04',' 钻石作家'); +INSERT INTO type VALUES ('L01','玄幻'), + ('L02','奇幻'), + ('L03','武侠'), + ('L04','仙侠'), + ('L05','都市'); +INSERT INTO story VALUES (1,'1002','L03','母猪产后与护理师的二三事',6541), + (2,'1005','L04','拖拉机大战蜘蛛侠',6541), + (3,'1003','L01','这只小龙虾不正经',563), + (4,'1006','L04','一个爹爹三个娃',8754), + (5,'1006','L01','皇上滚开本宫只劫财',36354), + (6,'1005','L05','给长城贴瓷砖的小太监',654), + (7,'1003','L03','不科学御兽',1257), + (8,'1005','L01','镜面管理局',3216), + (9,'1004','L02','关于我成为灭魂师之后',1147), + (10,'1004','L05','公子别秀',2078); +-- 1. 将story 表中的story_name字段类型改成varchar(40) 。(2分) +alter TABLE story MODIFY story_name varchar(40); +-- 2. 在author表中增加一个性别字段字段名:author_sex,类型:char(10),要求默认值(3分) +ALTER TABLE author add author_sex char(10) DEFAULT'男'; +-- 3. 将作家编号为1005、1007的作家性别改为'女' 。(2分) +UPDATE author set author_sex='女' WHERE author_id=1005 or author_id=1006; +-- --4.作家杜子腾,写了一篇名为《拜登夸我很帅》的都市小说,有854个浏览量,请将这条信息插入到story表(3分) +INSERT into story VALUES(11,1005,'L05','拜登夸我很帅',854); +-- 5. 《拖拉机大战蜘蛛侠》这篇小说,浏览量涨了100,请更新story表中的相关数据 + UPDATE story set views_number=views_number + 100 WHERE story_name='拖拉机大战蜘蛛侠'; +-- 6. 请删除story表的中《皇上滚开本宫只劫财》这篇小说相关数据。(2分) +DELETE FROM story WHERE story_name = '皇上滚开本宫只劫财'; +-- 7. 查询 浏览量大于 8000的小说的作者编号和小说作品名称。(2分) +SELECT story_id,story_name FROM story WHERE views_number > 8000; +-- 8. 查询积分大于1000 并且会员等级高于vip03的作家所有信息。(3分)\ +SELECT * FROM author WHERE credits > 1000 and vip_id >'VIP03'; +-- 9. 查询姓名以杜字开头的作家的姓名,积分和等级编号。(3分) +SELECT author_name,credits,vip_id FROM author WHERE author_name like'杜%'; +-- 10. 查询积分在100、1000之间的作家信息,以积分降序排列。 (3分) +SELECT * FROM author WHERE credits BETWEEN 100 and 1000 order by credits desc; +-- 11. 查询出小说的总浏览量,最高浏览量,最小浏览量,,给字段用上中文别名。(3分) +SELECT sum(views_number)总浏览量,max(views_number)最高浏览量,min(views_number)最小浏览量,avg(views_number)平均浏览量 FROM story; +-- 12. 查询各种等级的作家的平均积分和作家数量,并对查询结果使用中文别名。(3分) +SELECT vip_id 作家等级,avg(credits) 平均积分,count(author_name)作家数量 FROM author group by vip_id; + +-- 13. 查询小说数量大于等于2的分类编号和小说数量。(4分) +SELECT type_id,count(type_id) 小说数量 FROM story WHERE type_id>='L02' GROUP BY type_id; +-- 14. 查询所有小说中浏览量最少的书的作品编号、作品名称和类型编号、浏览量。(4分) +SELECT story_id,story_name,type_id,views_number FROM story WHERE views_number=(SELECT min(views_number) FROM story); +-- 15. 查询积分比刘产高的作者所有信息。(5分) +SELECT * FROM author WHERE credits>(SELECT credits FROM author WHERE author_name = '刘产'); +SELECT credits FROM author WHERE author_name = '刘产'; +-- 16. 查询出哪些白银作家是没有写小说的,显示这些作家的姓名、等级名称。(8分) +select a.author_name,a.vip_id from author a left join story b on a.author_id = b.author_id where story_name is null and vip_id=(select vip_id from vip where vip_name='白银作家'); + +-- 17. 找出写过作品浏览量大于5000的作家的所有作品中浏览量不到1000的作品信息(8分) + SELECT * FROM story WHERE author_id in (SELECT author_id FROM story WHERE views_number>5000) and views_number <1000; +); +-- 18. 查询所有小说的小说编号、小说名称、浏览量、分类名称、作者姓名、作者积分、作者等级名称,结果字段要用中文别名,并按浏览量降序排列,如果浏览量一样的,再按积分降序排列。(10分) +SELECT story_id 小说编号,story_name 小说名称,views_number 浏览量,author_name 作者姓名,credits 作者积分,vip_name 作者等级名称 FROM story \ No newline at end of file -- Gitee